BUY IN PRINT MAGPICC/STORE 


Issue 125 | January 2023 | magpi.cc The official Raspberry Pi magazine 


| BUILD AN 
„© AUTOMATED 
ec stadt 


X 


s 
Ea 


TTA 


Æ GLOBAL 
cary DELIVERY 
magpi.cc/store 


tees’ 


GET CREATIVE WITH RASPBERRY PI PICO 


UL) usten Industrial Raspberry Pi 


s @ BE TL 4) 2357 


Proagramminc 
ogramming 


© 
@ 
TW so 
oe 
X 


f=- 


A> 
Sd 
E 
a 
Le] 


Preferences 


ilePi 


The ComfilePi is a touch panel PC designed with high-tolerant components and no moving 
parts for industrial applications. It features a water-resistant front panel, touchscreen, 
color LCD (available in various sizes), RS-232, RS-485, Ethernet, USB, 12C, SPI, digital 10, 

battery-backed RTC (real-time clock), and piezo buzzer. 


Use the rear-panel 40-pin GPIO header to expand its features and capabilities with additional 
I/O boards. The ComfilePi is UL Listed and employs Raspberry Pi Compute Module. 
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Visit www.comfiletech.com © copyright COMFILE Technology, Inc. ALL RIGHTS RESERVED TECHNOLOGY 


WELCOME 
to The MagP1 125 


ith any luck, you found a Raspberry Pi gift under 
W the tree this Christmas. 
If you’re new: welcome to the party! Pull up a 
chair, pick up a copy of this magazine, and get ready for a 
wonderful world of making. 

You’ll find our Starter Guide on page 28, and a Raspberry Pi 
OS Guide on page 36. Newcomers to Linux should check out 
our Terminal Starter Guide (page 48). 

Meanwhile, veterans looking for inspiration really should 
read our Arts & Crafts guide (page 70), and we have some 
wonderful tutorials this month: from putting a Raspberry 
Pi camera in an aquarium (page 56) to building a display 
kiosk (page 60). 

I’ve loved putting together this issue. It’s great to be 


reminded of just how exciting it is to pick up Raspberry Pi for 


the first time. 
Happy Making! 


Lucy Hattersley Editor 
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Lucy 
Hattersley 


Editor of The MagPi. 
Lucy codes, crafts, 
and creates wonky 
robots. She's 
probably running 

in the Greenwich 
Pantomime Horse 
race about now! 
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Explore E-ink technology with EPDK from PERVASIVE DISPLAYS 
E-paper display (EPD) Pico Development Kit 


| g POWERED BY 


Raspberry Pi 
nannan A AE 


The EPD Pico Development Kit from Pervasive 
Displays includes everything to start exploring 
E-ink technology. 


EPD Extension board Gen 3 (EXT3-1) board 
Raspberry Pi Pico RP2040 (with pin header) 

2.66" E-ink Monochrome Display with Fast Update 
20-pins and 2-pins bridging cable 

Pin mapping label (3 pieces) 
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Grab a USB cable, download the library and start exploring E-ink technology today! 
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www.sparkfun.com/products/19219 ol 


Learn more PERVASIVE DISPLAYS 


www.pervasivedisplays.com 


Entaniya 


Cube Case 01 


for Single Board Computers 


Cube Case 01 provides safe housing for 
main units of Single Board Computers, e.g. 
Raspberry Pi 3 or 4. It has a high-quality 
machined aluminum frame, with many 
options such as interchangeable acrylic 
panels and perforated panels that allow 
cables to pass through. 


Dustproof and drip-proof in use with A free configurable case with Compatible with Entaniya All-Weather Case 
the included sealing mats replaceable panels WC-01 for Raspberry Pi Camera Module 2 
á (sold separately) 


For inquiries, please contact products@entaniya.co.jp 
Entaniya Co.,Ltd., Nishiwaseda 2-5-13, Shinjuku-Ku, Tokyo 169-0051, Japan | www.entaniya.co.jp 
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Get creative with Raspberry Pi Pico 


Get started with command line 
Build a DBS to USB converter 
Watch your aquarium anywhere 


Using Raspberry Pi in kiosk mode | sabe = i = o ar 3 Pee Z 
Build a Pico W web app , a ak a 


M! Watch your aquarium 


Vivace 


Top 10 Advanced projects 


ReTerminal Expansion E10-1 
RelayFi 

Top 10 Advanced projects 
Learn web design 


Jeff Geerling interview 
This Month in Raspberry Pi 


DISCLAIMER: Some of the tools and techniques shown in The MagPi magazine are dangerous unless used with skill, experience, and appropriate personal protection equipment. While 
we attempt to guide the reader, ultimately you are responsible for your own safety and understanding the limits of yourself and your equipment. Children should be supervised. Raspberry 
Pi Ltd does not accept responsibility for any injuries, damage to equipment, or costs incurred from projects, tutorials or suggestions in The MagPi magazine. Laws and regulations covering 
many of the topics in The MagPi magazine are different between countries, and are always subject to change. You are responsible for understanding the requirements in your jurisdiction 
and ensuring that you comply with them. Some manufacturers place limits on the use of their hardware which some projects or suggestions in The MagPi magazine may go beyond. It is 
your responsibility to understand the manufacturer's limits. 
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From millions of in-stock parts to the latest new 
product inventory, we've got everything you need 


to turn breakthrough ideas into reality. (Digi-Key 


ELECTRONICS 


Get inspired at or call 0800 587 0991. 


Digi-Key is afranchised distributor for all supplier partners. New products added daily. Digi-Key and Digi-Key Electronics are registered trademarks of Digi-Key Electronics inthe U.S. and 
other countries. ©. 2022 Digi-Key Electronics, 701 Brooks Ave. South, Thief River Falls, MN 56701, USA 
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K- 


Recreating a beloved TV character or prop is fairly 
exciting. Rosie Hattersley hears how Raspberry Pi 
allows one maker to give K-9 multiple Whovign features 


Fitz Walker 


Fitz is a maker/ 
tinkerer by nature 
with an unhealthy 
love for radio- 
controlled models 
of all types. 


magpi.cc/ 
hobbyview 
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Fitz Walker holds classic Doctor Who in 

very high regard. As an electrical engineer 
and computer scientist, he was better placed than 
many Whovians to show off his love of the show 
by building his own replica K-9, giving it “modern 
components” with Raspberry Pi. 

Keeping the ‘use whatever you’ve got to 
hand’ ethos of the original Doctor Who sets, a 
loo roll holder disguises an unexpected K-9 
defence mechanism. 

The K-9 project helped Fitz fulfil an ambition 
to build a film replica of one of their “favourite 
companions to my favourite Doctor” [Tom Baker, 
naturally] and “to experiment with Raspberry Pi 
and other microcontrollers, and electronics to see 
how well they might replicate all the animatronic 
and visual features of the hero prop.” 

Fitz chose Raspberry Pi for its “powerful 
computer processing and video display”, and 
options for interfacing with the physical world, 
giving K-9 “some level of autonomy and AI.” 


| ike many millions of us, “maker/tinkerer” 


Design cues 

Having been introduced to Raspberry Pi by a friend 

- who he thought was pranking him, based on the 

single-board computer’s name - Fitz realised it 

would suit his needs very nicely. “Once I realised 

its potential, I kept Raspberry Pi in mind for any 

projects I engaged in.” Raspberry Pi is “a powerful 

tool to do pretty much anything I can think of.” 
K-9 is the main focus of Fitz’s tinkering efforts, 

and the only project for which he has had to do 

any custom design work, since some aspects 

could be adapted from other people’s projects. 

In particular, founder of the K-9 Replica group 

Dave Everett had produced detailed templates 

and assembly guides for the animatronic dog’s 

body, including a basic mechanical framework 


The Tom Baker scarf is 
a nod to Fitz's favourite 
Doctor. He makes 
regular appearances 
on K-9’s built-in screen 
displaying old TV clips 


A Raspberry Pi 3 currently 
provides K-9's ‘brains’, 
helping him make tactical 
decisions and interact 


with humans and aliens 


(magpi.cc/kgbodyconstruction), which were 
quickly seized on by fellow Whovian makers. 
Another impressive K-9 Raspberry Pi build that 
we’ve covered (magpi.cc/k9prop) uses this 
template too, or you can join a dedicated builder’s 
Facebook group: magpi.cc/k9facebook. 


Building on the original 

Fitz also made use of existing designs for the very 
intriguing camera and AI element that he added to 
K-9’s head. This is “based, in part, on the wedding 
photo booth (magpi.cc/photoboothdiy) by Anthony 


a 


Sabatella which inspired K-9’s photo-taking 
abilities,” code which Fitz modified for K-9. 
“Pretty much all the electronics and most of the 
animatronics were designed and set up by myself,” 
says Fitz, who reports that the build was not 
complex but required “a bit of time and patience 
to build, program, and debug,” with integrating 
all the parts the most challenging aspect. “Like 
any project, unexpected things come up. The drive 
system was a bit troublesome at first and had to be 
totally redone. Even then, it has some directional 
instability that needed to be rectified with a gyro.” 


K-9's head contains a camera. 
Photos are analysed by 
Raspberry Pi before K-9 prints 
out a pronouncement on whether 
a human or alien is in sight 


Elementary school pupils have been lucky enough to get a surprise visit too 


Fitz's K-9 extras 
include a loo roll 
holder nose... 


„Which conceals 
a retractable 
laser gun 


There's a side 
monitor originally 
designed for cars.. 


„which plays a 
random selection 
of Dr Who clips... 


„or sometimes 


random waveform 
sounds from 
YouTube 
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ee 
POLICE $ BOX | 


é = e` ACA 7 K-9 is a combination of 3D-printed parts and 


te } : components sourced from online stores, including 
we AF A I, Adafruit and SparkFun. Since everything would 
$ j / eventually be hidden inside K-9’s body, Fitz did 

k ; all his prototyping on a separate bench using 


K-39 is a combination of 
3D-printed parts and 
components sourced from 
online stores 


a different Raspberry Pi, before transferring 
everything to the ready-assembled setup inside 
the robot. This requires some duplication of 
hardware, but makes life easier for a project with 
plenty of iterative revisions and “continuous 
coo p g modification and expansion.” Utilising the various 
Fitz's K-9 has made various appearances at i i 
shows in the US, often flanked by Daleks GPIO connections, to both read inputs from 
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Give K-9 new tricks 


4 Large bright buttons give 
K-9 an authentic 1970s look 


w K-9's scarf shows his 
allegiance to his favourite 
Doctor, clips of whom 
might well appear on- 
screen imminently 


Download templates for K-9's body 
and an electronics schematic from 
magpi.cc/kgbodyconstruction to either 3D-print 
or laser-cut. You will need at least a Raspberry 

Pi 2, plus plenty of servos, and a fair amount of 
mechatronics knowledge. 


C E L Ss 
k Species 

UNKOWN 
for the Doctor 


Recording results 


ni is 


If you want to add the Al camera feature, you 
can adapt code from this photo booth project: 
magpi.cc/photoboothdiy. You'll need a thermal 
printer to output K-9's ‘human or alien’ verdicts. 


an external trigger and to run various external 
devices, was a big challenge. He estimates the 
build took three months of fairly focused work, 
with some light additions over the course of the 
following year. After an outlay of roughly $1000, 
the only real running costs are for the thermal 
paper on which K-9 prints photos of whoever is 
in front of him, along with a wry take on whether 
they might be human or alien. 

You can see Fitz’s K-9 robot in action at 
magpi.cc/k9chronicles. Expect a new post soon, 
as he’s currently working on adding voice- 
recognition and Pico elements. H 


Fitz used Python on his Raspberry Pi 3 to 
control the camera/printer and eye lights 
in K-9's head, and to play video clips on K-9's 
side monitor. 
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Maka Niu 


A deep-sea underwater imaging and sensing system made using a Raspberry Pi Zero and 
Camera Module is making a splash in marine exploration circles, David Crookes dives in 


Katy Croff Bell 


Dr Katy Croff Bell 
is a deep-sea 
explorer with a 
background in 
ocean engineering, 
maritime 
archaeology, 

and geological 
oceanography. 
She is founder 
and president 

of the Ocean 
Discovery League. 


magpi.cc/ 
makaniu 
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t would seem there are few limits to where 

Raspberry Pi can go. The computer has been 

used in the Antarctic and on the International 
Space Station. It has also, as this project proves, 
plunged deep underwater - in this case, furthering 
scientific knowledge and enabling more people to 
explore the world’s oceans. 

Indeed, without Maka Niu - a small, low- 
cost, deep-sea image and data collection system 
that has Raspberry Pi at its heart - Katy Croff 
Bell, president of the Ocean Discovery League, 
says such exploration could continue to be the 
exclusive domain of the wealthy. “By making 
this technology open and available to anyone,” 
she says, “we hope to bring more equity to this 
important field.” 

This has far-reaching benefits. Less than one 
percent of the deep sea-floor has been seen and 
characterised, while most coastal countries lack 
the tools needed. “Ultimately, more observations 
will result in more discoveries and a better 

understanding about the single 
largest biosphere on Earth,” 
she adds. 
Not bad for a project that 
was initially earmarked for 
the Festival of the Pacific 
Arts and Culture, aimed 
at teaching high school 
students about deep- 
sea exploration 
and research. 


Sensing the 
ocean 
“The idea for 
Maka Niu had been 
brewing for a few 
years while I led 


4 A Raspberry Pi Camera 
Module V2 fits neatly 
at the end of the 
project's housing 


the Open Ocean Initiative at the MIT Media Lab,” 
Katy explains. “The spark was a trip to Hawaii in 
January 2020 where my team and the MIT Future 
Ocean Lab were working with the Polynesian 
Voyaging Society and decided to create a small, 
low-cost camera.” 

The festival was cancelled due to Covid-19, but 
Katy says this allowed the group to take a step 
back and work on making the end product even 
better than originally envisioned. “In the last five 
to ten years, there has been a growing movement 
towards the development of lower-cost systems, 
but still many of them can’t go very deep (tens or 
hundreds of metres) or they can only collect one 
type of data such as imagery,” she says. 

“Maka Niu can collect several types of 
data including video and still imagery, depth, 
temperature, and GPS location when out of the 
water. It can go up to 1500 metres below sea 
level, and we have designs to go 6000 metres 
which would enable it to reach 99 percent of the 
sea floor. 

“It’s designed to be modular so you can create 
other types of sensors or modules using the same 
housing, battery pack, and electronics. And we’ve 
designed the interface so that it’s really easy to 
program, use, and see your video stills using a 
smartphone or tablet without internet access.” 


A deep mission 
The use of Raspberry Pi felt natural. “The need for 
an imaging system that would be at least HD led 
to the adoption of Raspberry Pi Zero and Raspberry 
Pi Camera Module V2,” affirms Ocean Discovery 
League imagineer Dan Novy. “Brennan Phillips, 
from the University of Rhode Island, had created 
an epoxy potted [Raspberry] Pi-based camera 
called DEEPi which showed promise, and the cost 
and physical dimension of Raspberry Pi Zero were 
perfect in keeping the device small but powerful.” 
Dan says there’s a Node.js-based mission engine 
accessed over Wi-Fi from a browser on a phone, 
tablet, or laptop. “Each Maka Niu acts as its own 


| MéigPi 


Raspberry Pi Zero is mounted l 
inside Maka Niu and its on-board f 
Wi-Fi allows communication and | 
video download without opening | 
the sealed, watertight unit | 


Calculations by Allan Adams, 

of Oceanic Labs, showed using 

polyoxymethylene for the main | 
pressure housing would allow Maka 


> Maka Niu means 
| 


The project currently Niu to descend at least 1500 metres [i | “coconut eye” 

uses 10mm acrylic for io, 

the main camera port, > It as een 

but using sapphire glass designed to 
be modular 


would allow the device to 
descend to 6000 metres, 
putting 99.9% of the ocean 
within imaging range 


> The tech is open 
and available to all 


> Data can be 
uploaded to image 
analyser Tator 


More observations 
will result in more 
discoveries and a 

better understanding I 


> The ideal sensors 
were chosen 
by marine 
professionals 


access point for direct communication between 
the browser and the mission engine, or the device 
can join a Wi-Fi network in client mode and, 
again, become accessible via browser-to-program 
missions or to review and upload footage in the 
cloud or download it to local storage,” he adds. 
“The simplified programming environment 
allows the unit to be programmed in a LEGO- 
like fashion and allows non-programmers to be 
able to visually create missions just by stacking 
blocks of certain tasks and triggers into a loop that 
runs perpetually.” 


4 Using a pre-existing 
single-board 
computer such 
as Raspberry Pi 
Zero enables 


In the future, the idea is to use AI to — { j more people to 
automatically view and annotate mission footage. meea S ea 
“We are working with CVision AI, scientists at the SEE — development 
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This alternative 
deployment makes use 
of a coconut float. The 
end cap of the device | 
houses a GPS receiver, s JA p! 


: | š 
compass, and inertial A 
measurement unit l a EON An | 
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Delving deep underwater 


+è 


01 The imaging sensor is able to take videos and 
stills. This turtle image is very clear, although 
it was snapped in relatively shallow water. 


02 There's a well-hidden rockfish in this image! All 
samples are time and location stamped down 
to the millisecond. 


4 Dan Novy says inductive 


m The cost and physical Boles obs newer 


charged wirelessly 


dimension of Raspberry 
Pi Zero were perfect in 
keeping the device small 
but powerful @ 


Monterey Bay Aquarium Research Institute, and 
others, on developing machine learning algorithms i ; 
; Blend Maka Niu has captured a sea urchin. A small 

for automated detection and classification of 03 buzzer-style motor provides haptic feedback 
; ; ” ; 4 

organisms and other things,” Katy explains. letting the user know the device is taking an image 

“The collaborative design is just one step along a or video. 

long-term path of continued co-development.” Hi 
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If the idea of asking a neighbour to water your 
houseplants while you're away is rather awks, 


this Raspberry Pi project will save your blushes, 
Suggests Rosie Hattersley 


16 | magpi.cc | 


Vanessa 
Bradley 
and Martin 
Spendiff 


VEEB began 

as a lockdown 
photography 
project for Vanessa 
Bradley and Martin 
Spendiff and soon 
morphed into a 
site documenting 
their builds. 


m veeb.ch 


ourdough baking, getting a pet and 
™ decluttering your home before filling it with 
houseplants to make it Instagram-worthy 
all had their moment during the Covid pandemic. 
Of these three trends, acquiring indoor plants 
appears to have had the most longevity. If you’re 
off to visit friends and family over the festive 
break, or jumping on the long-vacation-to- 
avoid-winter-and-heating-bills bandwagon, it 
might be time to consider how your plants will 
fare while you’re away. This Pico Plant Waterer 
saves you bothering a neighbour to pop in and do 
the honours. 
For Vanessa Bradley and Martin Spendiff, 
collectively known as VEEB, the scenario came 
up because their “lovely” neighbour sometimes 
watered their houseplants, but the plants didn’t 
always survive the experience. To save any more 
plants dying, they designed a carefully calibrated 
mechanism that would test whether the soil was 
dry enough for the plant to need watering, provide 
“a squirt” if needed, then check whether more 
moisture was required and apply it. Raspberry Pi 
was an obvious choice as they’d built a number of 
projects based on it before, some of which we’ve 
covered previously in The MagPi. 
Vanessa originally worked in IT and Martin as 
a scientist, but they were “a bit bored” of their 


Pico Plant Waterer 


professions and became photographers instead. 
Their respective technical backgrounds and flair 
for visuals took off during lockdown, documenting 
their creations at veeb.ch. “We always had 
Raspberry Pi computers dotted about doing stuff. 
During lockdown we started building things that 
were a bit more involved,” Martin explains. 

He says one of the real pluses of using 
Raspberry Pi is documentation. They used a Pico 
for their plant watering project, which meant 


j ` ‘ol _. Apu MägPi 


VEEB'’s demo video celebrates a 
successful week of automatically 
watering, but not overwatering, 
their peace lily 


WN 


If the plant is thirsty, “a 

squirt” of water is syphoned 
into the plant pot, then the 
moisture levels checked 
again before any more 
watering is done 


Raspberry Pi Pico uses 
information from a capacitive 
soil monitor pushed into the 
soil to determine whether 
the plant needs watering 


= 


Martin envisaged 
Clive Moss the 
Window Box 
Boss with.. 


„a blonde wig 
to look like their 
neighbour 


“We totally 
chickened out 
in case she ever 
saw it!” 


Clive originally 
had a screen 


and controller 
Martin and Vanessa's helpful 
neighbour “invariably kills 
the plants" she's been asked 
to water, “so the idea was 

to see if we could make 
something to replace her" 


VEEB boxed him 
up instead for 
simplicity and cost 
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& Pico Plant Waterer is 
adapted from VEEB's 
automatic burger 
cooking project 


A 


Warning! 
Water & Relay 


Water can damage 
low-voltage electrical 
equipment. Water with 
mains-voltage electricity 
can be deadly. 


magpi.cc/ 
electricalsafety 


losing some of the Python libraries in the switch 
to MicroPython, “but there isn’t a huge leap from 
[Raspberry Pi] Zero to Pico and there is an elegant 
simplicity to a little board that just does one thing, 
the moment that you turn it on.” 


If it ain't broke... 
VEEB projects tend towards the weird and slightly 
wacky, such as an old Teasmade linked to a 
Google Calendar (magpi.cc/goblineteasmade) and 
a Boombox Jukebox (magpi.cc/boomboxjukebox). 
“The general pattern that has emerged is taking 
some simple/older technology, linking it to newer 
tools, figuring out something that could be useful, 
making a simple proof of concept,” says Martin. 
Clive Moss the Window Box Boss, as the Pico 
Plant Waterer has been named, is really a revamp 
of a VEEB project which cooks burgers in a water 
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bath (magpi.cc/betterburger). “It’s a pretty 
general-purpose controller that can be applied 

to various situations that require some sort of 
monitoring/intervention.” Aside from the switch 
to Pico, little hardware was needed beyond what 
they had lying around. Martin and Vanessa bought 
a cheap fish tank pump and got any extras they 
needed from the local hardware store. 

“We took the burger cooker, removed the screen 
and controls, and popped it all in a waterproof 
box. The only part we made was bending a paper 
clip to hang it on the side of a plant pot.” 


Intelligent watering system 

Watering a plant is only half the equation; 

the other part is checking whether the soil is 
sufficiently wet. As Vanessa notes, “not all types 
of plant require the same level of moisture.” 


Although the moisture sensor helps provide this 
information, common sense is needed too: Martin 
admits the first time they trialled the setup, all 
the water was pumped into the plant pot at once. 


m We always had Raspberry 
Pi computers dotted about 
doing stuff Ø 


“We were too stupid to remember that the siphon 
effect was a thing, so on the first run of the code 
we just looked puzzled as a couple of gallons of 
water emptied into a plant pot while the pump 
wasn’t even turned on.” Moving the water tank 
further away helped. “The distance between water 
source and sensor means that when it has dried 
out, it drops a lot of water at once. This was 
initially an accident, but it turns out it promotes 
root growth.” m 


a Clive Moss the Window Box 
Boss is “the man with the 
plan for a hosepipe ban" 
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Power up your plants 


01 Aside from a Raspberry Pi Pico anda 
capacitive moisture sensor, you will need AA 

batteries, a pump, a large water container, a relay 

switch, and some clear tubing. 


02 You can download the MicroPython setup 

code from magpi.cc/sploosh or view the 
demo video at magpi.cc/youwatertheplant. Once 
set up, fasten the tube to the edge of the plant pot. 


0 The water source needs to be kept some 
distance from the plant to ensure it doesn't just 
decant the jug's contents straight into the plant pot. 

If all goes well, you should have a healthy plant, even 
after a week away from home. 
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Viini Mars Rover 


Meet the inventive maker who decided to create his very own 
miniature Mars rover. Nicola King learns all about roving robotics 


T: 

mA Nikodem 

M Bartnik 

: j | A 23-year-old 
maker from 
Poland, Nikodem 
is currently 
studying at the 
Silesian University 
of Technology. 
His projects are 


focused on robotics, 


programming, 
3D printing, and 
CNC machines. 


ttracted by Raspberry Pi Pico W’s built-in 

Wi-Fi and the ability to program it in 
E \\ MicroPython, Nikodem Bartnik knew he 
had to make a project with one, but wasn’t sure 
exactly what. Inspiration struck when he attended 
a CubeSat Summer School in Belgium. On a visit 
to the Euro Space Center, he saw a field with mini 
Mars rovers. 

Nikodem had to fit the building of his own 
remote-controlled Mini Mars Rover around his 
other university work, and there was plenty 
to do, including designing it from scratch in 
CAD and undertaking a lot of 3D printing and 
CNC machining. 

“All parts were designed in such a way that 
you can print them on the most popular FDM 3D 
printers and you don’t need a huge build plate,” he 
says. “The bottom plate was machined on my DIY 
CNC machine - IndyMill (magpi.cc/indymill)... 
The principle of how it works is very simple; 
designing and 3D printing it is not.” 

He also kept adding more features while 
working on the project. In particular, the robotic 
arm was an especially time-consuming part, 
with Nikodem designing and then redesigning it 
multiple times until it worked. The 3D printing 
aspect took around 24 hours in total but, in the 
end, all parts worked beautifully. 


Core components 
Raspberry Pico W is integral to the Rover: “Thanks 
to Pico W, it is possible to control it through Wi-Fi 
and [a] simple Python script on a computer,” 
explains Nikodem. The script is created with 
Pygame and a simple custom class he developed 
for the simple user interface elements he needed. 
“For controlling the micro servo motors, I am 
simply using 50Hz PWM signal. For DC motors I 
am using popular and cheap drivers, L298N, and 
control them through PWM and digital pins,” he 
explains. He also added an FPV camera system to 
the build, which turned out to be far simpler than 
he’d imagined. “I had no experience with FPV 
systems before; it was completely new to me, but 
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it turned out to be super-straightforward and it 
works great.” 


Small and sharable 

Nikodem was determined to make his project 

as clean and small as possible “for aesthetics 
reasons, but also for its safety and functionality,” 
he underlines. He also wanted to be able to share 
his work with others and make it easy to replicate, 
so he chose to make his own custom PCB, using 
a cheap CNC machine he’d modified. “The best 
part about this setup is: in the morning I design 
a PCB and, by the afternoon, I have it ready 

for soldering.” 

Nikodem’s Rover has received plenty of positive 
comments and he admits “that was a big relief 
after working on it for so long.” There were a few 
people who suggested that the Rover’s wheels 
wouldn’t survive the Mars environment, but 
Nikodem is pragmatic as “it was quite obvious 
for me from the beginning that the purpose of the 
project is to educate and inspire. Building it in 
the way real Mars rovers are built is completely 
unrealistic and unnecessary.” 

Excitingly, Nikodem is now concentrating on 
his bachelor thesis project which will use Pico’s 


The chassis parts were 
3D-printed, including 
the mount for the first- 
person view camera 


The Rover's mecanum wheels 
enable it to move sideways 
for maximum manoeuvrability 


RP2040 chip. “I am currently testing the PCB for b 
the project... The end goal is to be able to take 
long exposures of deep sky objects with a camera 


m Thanks to Pico W, it is 
possible to control it 
through Wi-Fi and a 
Simple Python script on 
a computer Ø 


by compensating the movement of Earth and also 
create a go-to system with Stellarium.” 

If you take a look at Nikodem’s YouTube 
channel (magpi.cc/nikodemyt), you’ll see a huge 
and interesting array of projects he’s worked on so 
far, and it seems there will be plenty more to come 
from this very talented maker. 


A Pico is connected via a custom PCB to the 
servos and driver boards for the motors 


PROJECT SHOWE) 


A robotic arm enables the 
Rover to pick up samples 


from the planet's surface 


> 


v 


v 


v 


v 


Nikodem estimates 
the project cost 
him around $150 

to make 


The Rover is 
open-source and 
all files are on 
GitHub: magpi.cc/ 
picomarsrover 


It's powered by a 
650 mAh 2S LiPo, 
with two voltage 
regulators on the 
custom PCB 


Nikodem says, 
“Feel free to fork 
the repo, build it on 
your own, expand, 
and experiment!" 


He adds, “Don't 
forget to send 
me an email with 
the results’ 
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PiCar 


Upgrading a vehicle's entertainment system can be as simple or 
complex as you'd like. Rob Zwetsloot checks out a complex one 


Vincent 
Moscaritolo 


Retired software 
engineer 
specialising 

in privacy and 
cryptography, and 
one of the original 
Cypherpunks. 


magpi.cc/picar 


> The full hardware 
powering the display 
behind the scenes 
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honoured tradition among mechanics 

and engineers. Upgrading the sound system 
has always been a part of that too. However, 
that usually means putting in a pre-made 
head unit and maybe replacing the speakers. 
Vincent Moscaritolo has gone a step further with 
the sound system, giving it a full Raspberry 
Pi makeover. 

“T have made extensive modification to my 

Jeep, including replacing the motor with a Chevy 
LS 6.0 V8,” Vincent tells us. “This required 
some hacking into the Jeep’s CAN bus to fool 
the Jeep into thinking it still has a motor. There 
is so much useful information present on the 
network that is not presented to the driver, and it 
frustrated me that one of the main user interfaces 
on the vehicle, the car radio, does not present or 
allow the driver to access it.” 


T inkering and modifying a car is a time- 


Vincent looked at various solutions, but they 
didn’t quite fit the Jeep’s aesthetic. He decided to 
make something a bit more custom using a VFD 
(vacuum fluorescent display) to fit the original 
look, and even fool folks into thinking it was the 
stock radio. 


Farm to auto 

After using Raspberry Pi to fix an automated 
chicken coop, Vincent started using it more 
in projects. 

“T found that it was fairly easy to use Raspberry 
Pi to interface to the CAN bus as well as 12C,” 
Vincent explains. “Since it was a Linux-based 
platform, it was also easy to talk to the various 
software-defined radio (RTL-SDR) devices 
out there.” 

Even with a familiarity with Raspberry Pi, and 
ease of access to the interfaces, the project hasn’t 
been without issues. 

“Tt has been a learning experience,” Vincent 
says. “While there are a lot of folks building 
things for Raspberry Pi, not a lot of the software 
or hardware is rugged enough to put in an 
automotive application. A lot of tools, while 
pretty cool, were written at the hobbyist level. 
For instance, most of the software-defined radio 
(SDR) tools require a desktop display, and can’t 
be used in a car radio app. 

“The other problem was that the automotive 
manufacturers are really proprietary and secretive 
about how their systems work. I had to mostly 
adjust the Jeep CAN network packet information 
by trial and error, such as monitor the packets, 
open a car door, and see what changes, etc.” 


MägPi 


The screen replicates the original 
Jeep Wrangler stereo system 


A little bit of painting 
and detailing is all that's 
70° 783"°F 1:31pm left before it's installed 


” 


So. County Fire 
UHF 154.318 Mhz 
. -55 
PRESET 


The rotary encoders Vincent has been 
have attached LED working on and off 
rings to show how much for a year 

you've turned them 


The major functions 
have been working 
for six months 


OLED displays 
looked washed out 
in sunlight to Vincent 


Vincent moved the 
GPIO head to below 
the board 


It could run ona 
slower Raspberry Pi 

- it currently tops out 
at about 30% CPU 


Visita 


AirPlay from Apple devices works, so 
people don't need to grab an aux cable 
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SNAP South 12:51PM 
DISTANCE GERZING 


10.24 mi 169°r 
o" 


ume: 
10T 526851 4678466 


The GPS is more for positioning, 
which helps with hiking and such 


The rotary encoders have the LED 
rings built in and work very nicely 


24 magpi.cc PiCar 


PROJECT SHOWCASE | MägPi 


How it works 


Data is taken from the CAN (Controller Area 
Network), a standard car data port that allows 
access to various information that mechanics and 
sometimes even the car can read. This can include 
engine operations, tyre pressure, fuel supply, etc. 


7 


4 The display and knobs In the end, Vincent wrote a custom application 
are to replicate the r a 
original stereo system in C++ that talks to the VFD over the serial port. 
on the Jeep It monitors the states of the knobs and the CAN 
bus, talks to a GPS board via serial, and the SDR 
via USB. 


With some hacking, the data is stored and 
translated to work on the limited VFD via 
several predetermined screens. The code also 
looks out for changes in the knobs to know when to 
display it. 


u | found that it was fairly 
easy to use Raspberry Pi 
to interface to the CAN 
bus as well as 12C Ø 


Finishing touches 

‘{It’s] just about ready to replace the existing 
radio,” Vincent tells us. “I am currently 
alternating between it sitting on my shop desk 
and my dashboard. I have a temporary harness 
cabled that allows me to plug it [in] and move 
it back and forth. I need to paint and engrave 
the faceplate.” 

Apparently reactions have been varied - folks 
who know what he’s made are blown away while 
others are at least appreciative of the display. 
Count us in as one of the blown-away parties. m 


¢ 


The head unit displays regular information 
such as the radio, but can be changed for more 
detailed engine statistics, or even GPS, using the 
rotary dials like normal knobs. It also maintains the 
standard Jeep radio aesthetic 
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RP2040-based 
Raspberry Pi Pico W 
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ongratulations on becoming a Raspberry Pi explorer. 


We're sure you’ll enjoy discovering a whole new 

world of computing and the chance to handcraft your 
own games, control your own robots and machines, and 
share your experiences with other Raspberry Pi fans. 

Getting started won’t take long: just corral the extra 
bits and bobs you need on our checklist. Useful additions 
include some headphones or speakers if you’re keen on using 
Raspberry Pi as a media centre, or a gamepad for use as a 
retro games console. 

To get set up, simply use your pre-written microSD card 
(or use Raspberry Pi Imager to set up a card) and connect all 
the cables. This guide will lead you through each step. You’ll 
find the Raspberry Pi OS, including coding programs and 
office software, all available to use. After that, the world of 
digital making with Raspberry Pi awaits you. 


Raspberry Pi Starter Guide 


All the bits and bobs you need 
to set up a Raspberry Pi computer 


A Raspberry Pi 

Whether you choose the new Raspberry 
Pi 400; or a Raspberry Pi 4, 3B+, 3B; 
Raspberry Pi Zero or Zero 2 (or an older 
model of Raspberry Pi), basic setup is the 
same. All Raspberry Pi computers run 
from a microSD card, use a USB power 
supply, and feature the same operating 
systems, programs, and games. 
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a 
Aos® USB mouse 
= A tethered mouse that physically attaches to 
an 
we think it’s best to perform the setup with a 
wired mouse. Raspberry Pi sells an Official Mouse 


your Raspberry Pi via a USB port is simplest and, 
unlike a Bluetooth version, is less likely to get 

8GB microSD card (magpi.cc/mouse). 

You’ll need a microSD card with a capacity of 


lost just when you need it. Like the keyboard, 
8GB or greater. Your Raspberry Pi uses it to store Ti 


A 

games, programs, and boot the operating system. 

Many Raspberry Pi computer kits come with a card Power supply 

pre-written with Raspberry Pi OS. If you want to Raspberry Pi 4 and Raspberry Pi 400 ‘ 

reuse an old card, you'll need a card reader: either need a USB Type-C power supply. f. 

USB or a microSD to full-sized SD (pictured). Raspberry Pi sells power supplies \ S— 
(magpi.cc/usbcpower), which i \ ‘ 
provide a reliable source of power. y hh \ 
Raspberry Pi 1, 2, 3, and Zero models 

Windows/Linux PC or Mac computer need a micro USB power supply << 

You’ll need a computer to write Raspberry Pi OS (magpi.cc/universalpower). = 

to the microSD card. It doesn’t matter what = 


operating system this computer 


runs, because it’s just 4 vA 
pe by SP? Display and HDMI cable 
bs 


for installing the OS 
using the Raspberry Pi >< A standard PC monitor is ideal, as 
Imager app. the screen will be large enough 
to read comfortably. It needs 
to have an HDMI connection, 
as that’s what’s fitted on your 
Raspberry Pi board. Raspberry 
Pi 4 and 400 can power two 
HDMI displays, but require a 
micro-HDMI to HDMI cable. 
Raspberry Pi 3B+ and 3A+ 


USB keyboard both use regular HDMI cables; 
Like any computer, you need a means to enter web Raspberry Pi Zero W needs a mini-HDMI 
addresses, type commands, and otherwise control to HDMI cable (or adapter). 


Raspberry Pi. The Raspberry Pi 400 comes with 
its own keyboard. Raspberry Pi sells an official 
Keyboard and Hub (magpi.cc/keyboard) for 
other models. USB hub 
Raspberry Pi Zero and Model A boards 
have a single USB socket. To attach a \ 

2 - keyboard and mouse (and other items), \ 
: you should get a four-port USB hub \ 
(or use the official USB Keyboard 
and Hub which includes three ports). eal 
Instead of standard-size USB ports, BS 
Raspberry Pi Zero has a micro USB port 
(and usually comes with a micro USB to 
USB-A adapter). 
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The USB-C socket is used to connect power 
to the Raspberry Pi 400. You can use a 
compatible USB-C power adapter (found 
on recent mobile phones) or use a bespoke 
power adapter such as the Raspberry Pi 
15.3W USB-C Power Supply 


Raspberry Pi 400 has its own 
keyboard - all you need to connect 
is the mouse and power 


Connect a mouse 

Connect a wired USB mouse to the white 
USB connection on the rear of Raspberry Pi 
400. The two blue USB 3.0 connectors are faster 
and best reserved for external drives and other 
equipment that need the speed. 


f{yxon 
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The Ethernet socket can be used to connect 
Raspberry Pi 400 directly to a network router (such 
as a modem/router at home) and get internet 
access. Alternatively, you can choose a wireless 
LAN network during the welcome process 


Attach the micro-HDMI cable 

Next, connect a micro-HDMI cable to one of 
the micro-HDMI sockets on the rear of Raspberry 
Pi 400. The one next to the microSD card slot is 
the first one, but either connection should work. 
Connect the other end of the HDMI cable to an 
HDMI monitor or television. 


The microSD 

If you purchased a Raspberry Pi 400 
Personal Computer Kit, the microSD card will come 
with Raspberry Pi OS pre-installed. All you need 
to do is connect the power and follow the welcome 
instructions. If you do not have a Raspberry Pi OS 
pre-installed microSD card, follow the instructions 
later in ‘Set up the software’. 


Das UP no Um LETTER 


Raspberry Pi 4 / 3B+ / 3 has plenty of 
connections, making it easy to set up 


Hook up the keyboard 

Connect a regular wired PC (or Mac) 
keyboard to one of the four larger USB-A sockets 
on a Raspberry Pi 4 / 3B+/ 3. It doesn’t matter 
which USB-A socket you connect it to. It is 
possible to connect a Bluetooth keyboard, but it’s 


much better to use a wired keyboard to start with. 
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Connect a mouse 
Connect a USB wired mouse to one of the 
other larger USB-A sockets on Raspberry Pi. As 
with the keyboard, it is possible to use a Bluetooth 
wireless mouse, but setup is much easier with a 
wired connection. 


HDMI cable 

Next, connect Raspberry Pi to your display 
using an HDMI cable. This will connect to one of the 
micro-HDMI sockets on the side of a Raspberry Pi 
4, or full-size HDMI socket on a Raspberry Pi 3/3B+. 
Connect the other end of the HDMI cable to an HDMI 
monitor or television. 
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You'll need this micro USB 
to USB-A adapter to connect 
wired USB devices such as a 
mouse and keyboard to your 
Raspberry Pi Zero W 


EH 
710) (Q O}F 
— J 

a 


PTT TT 


00) 


Raspberry Pi Zero W features 
a mini-HDMI socket. You'll 
need a mini-HDMI to full- 
sized HDMI adapter like this 
to connect your Raspberry Pi 
Zero W to an HDMI display 


ys ect. S 


to ra 


000000000000000000 
00000000000000000000 


Pissdaddd oe” 


Mouse and keyboard 
You can either connect your mouse to a 


i USB socket on your keyboard (if one is available), 
You'll need a couple g adapters to then connect the keyboard to the micro USB 
set up a Raspberry Pi Zero computer socket (via the micro USB to USB-A adapter). 
Or, you can attach a USB hub to the micro USB 


to USB-A adapter. 
Get it connected 
If you’re setting up a smaller Raspberry 
Pi Zero, you’ll need to use a micro USB to USB-A 


adapter cable to connect the keyboard to the More connections 

smaller connection on the board. Raspberry Pi Now connect your full-sized HDMI cable 
Zero models only have a single micro USB port for to the mini-HDMI to HDMI adapter, and plug the 
connecting devices, which means you'll need to adapter into the mini-HDMI port in the middle of 
either get a small USB hub or use an all-in-one your Raspberry Pi Zero. Connect the other end of 
mouse and keyboard. the HDMI cable to an HDMI monitor or television. 
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First, insert your microSD 
card into Raspberry Pi 


B Raspberry Pi 


Raspberry Pi OS 


With the microSD card fully 
inserted, connect your power 
supply cable to Raspberry Pi. A 
red light will appear on the board 
to indicate the presence of power 


This BOOTSEL button is used 
to connect Pico to a computer. 
Hold it down when powering 
on and Pico appears as a drive 
on the other machine - 5 > A USB to micro USB 


cable is used to connect 
Pico to another computer 
which is used to program, 
debug and transfer files 


~~ 
>. eS 
<< 
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Program Pico using a development environment 


Open Thonny 
The best way to program in MicroPython on 
your Raspberry Pi Pico is with the Thonny Python 
IDE (integrated development environment). Open 
the Raspberry Pi menu and choose: Programming 
> Thonny Python IDE. 

If you are using a non-Raspberry Pi computer 
you may have to install Thonny. Follow the 
instructions at thonny.org. 


m Thonny is normally used to 
write programs that run on 
the same computer you're 
using Thonny on Ø 


Choose interpreter 

Thonny is normally used to write programs 
that run on the same computer you’re using 
Thonny on; to switch to writing programs on your 
Raspberry Pi Pico, you’ll need to choose a new 
Python interpreter. Look at the bottom-right of the 
Thonny window for the word ‘Python’ followed by a 
version number: that’s your current interpreter. 


Click ‘Python’ and look through the list that 
appears for ‘MicroPython (Raspberry Pi Pico)’ - 
or, if you’re running an older version of Thonny, 
‘MicroPython (generic)’. 


Hello World 

Writing a program for your Raspberry 
Pi Pico is a lot like writing a program for your 
Raspberry Pi. You can type commands in the Shell 
area at the bottom of the window to have them 
immediately executed, or you can write a program 
in the main part of the window to run on-demand. 

Click in the Shell area, next to the >>>> 

symbols, and type: 


When you press ENTER at the end of the line, 
you’ll see your Raspberry Pi Pico respond. 

You are now ready to start writing your 
MicroPython code in the main window. Click Run 
to start the program on Raspberry Pi Pico. Take 
a read of our book, Get Started with MicroPython on 
Raspberry Pi Pico if you want to learn more about 
Pico programming (magpi.cc/picobook). K 


If you don't see 
‘MicroPython 
(Raspberry Pi 
Pico)’ in the 
interpreter List, 
you'll need to 
update Thonny. 
Open a Terminal 
window and type: 
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Navigate the official operating system and its applications 


hen you first power up Raspberry 
W Pi, you will be greeted by a Welcome 

Wizard that takes you through the 
initial setup process for the operating system, 
including locale settings, creating a user, and 
connecting to Wi-Fi. Once setup is complete, 
you are prompted to restart 
Raspberry Pi. After a short 
delay, you will then see the 
Raspberry Pi OS desktop. 


Around the desktop 
The desktop GUI for 
Raspberry Pi OS looks similar 
to that on many other 
computer systems. At the 
top is a taskbar that shows 

a few pinned applications 

on the left: by default, the 
Chromium web browser, File 
Manager, and Terminal. The 
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taskbar will also show tabs for any currently open 
applications or windows. 

At the right end of the taskbar are some icons 
for Bluetooth, Wi-Fi, and audio. Left-clicking 
these brings up some basic options, such as a 
volume slider for audio. Right-clicking the audio 
icon also allows you to choose the audio output 
(if your Raspberry Pi has a 3.5mm AV jack, or has 
an add-on sound card connected). Hovering over 
the icons will also bring up information on their 
status, including your Raspberry Pi’s IP address 
for Wi-Fi. 

At the far right of the taskbar is the current 
time (sourced from the internet). Hovering over it 
shows the date. Clicking it brings up a calendar. 


Applications menu 

At the top left of the taskbar is a Raspberry Pi 
icon. Clicking this brings up the applications 
menu. If you have installed the standard 32-bit 
version of Raspberry Pi OS, by default this will 


show the following 
categories: Programming, 

Internet, Sound & Video, Graphics, Accessories, 
Help, and Preferences. 

If you installed the ‘Full’ (not default) 
version of Raspberry Pi OS, your applications 
menu will include extra software packages 
such as Claws Mail and LibreOffice, some of 
them in new categories. You can install such 
software manually, by going to Preferences 
> Recommended Software. To install an 
application, tick the check box to the right of 
it and then click Apply. Once installed, it will 
appear in the applications menu. Similarly, to 
remove a previously installed application, untick 
it from the list. 

Even more software packages are available by 
going to Preferences > Add/Remove Software. As 
with the Recommended Software tool, you can 
view applications by category and tick the box 
next to a package to install it. 

You can also install extra software in the 
Terminal application, using the APT package 
manager. The Terminal is a powerful command- 
line interface for entering all sorts of commands 
- see this issue’s tutorial for more details. 


File and web browsing 
The File Manager on Raspberry Pi OS enables 
you to browse files and folders stored on the 


microSD card, along with removable storage 
media connected via USB. There are two main 
view modes: ‘icons’ and ‘list’. You’ll find the 
most useful folders (also known as ‘directories’) 
in your home folder, including Documents, 
Downloads, and Pictures. The Bookshelf 

folder enables you to download and view 

your favourite Raspberry Pi Press magazines, 
including The MagPi. 


ø You can also install extra 
software in the Terminal D 


For surfing the web, Raspberry Pi OS comes 
with the Chromium Web Browser pre-installed. 
This is the open-source project behind the 
Google Chrome browser, so will look fairly 
familiar to many users. At the top is an 
omnibox to type URLs or search terms (using 
the DuckDuckGo search engine by default). You 
can visit any site you like, including YouTube to 
watch videos - alternatively, you can view and 
listen to media in VLC Media Player, including 
web streams. 
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m Notifications appear in 
the taskbar when new 
updates are available @ 


System update 

For access to the latest features and important 
security measures, you will want to keep 
Raspberry Pi OS up to date. Fortunately, this is 
made easy using the update notifications that 
appear in the taskbar whenever new updates - 
for the system or applications - are available. 
You can then opt to install them from the 
dialog window that appears. 
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If you want to reboot or shut down your 
Raspberry Pi, select Shutdown from the 
applications menu, then select the desired 
option. To avoid the possibility of losing data, it’s 
advisable to shut down your Raspberry Pi before 
disconnecting the power. 


Start learning to code using the popular Python programming language 


to code. We’ll take you through the basics 

of Python programming. In the desktop 
applications menu, go to Programming > Thonny 
Python IDE. 

Thonny starts up in simple mode by default. 
Along the top are icons including Load, Save, 
Run, and Stop. The main panel is where you will 
write lines of Python code. At the bottom is the 
Shell panel where you’ll see the output from your 
programs, and any error messages resulting from 
a running program. 


Yy our Raspberry Pi is ideal for learning how 


Hello world 

Let’s start with the simplest of programs: 
printing a message to the Shell. In the main 
Thonny panel, add the following line: 


When using a print statement in Python 3, 
brackets must be used to enclose the output (as 
with any other function). The double quotes 
are used to enclose a text message (known as a 
string). Run the program (you’ll be prompted 
to save it) and it will print the message to the 
Shell. Try changing the text between the double 
quotes and rerunning it. 


Variables 

Variables are used to store values that may 
change in your program. You can define one and 
set it to a value using the = symbol, such as: 


Here, we have set the variable called ‘issue’ to 
125. We can also set a variable to store a text string: 


We can then add these variables to a print 
statement, along with other text strings, separated 
by commas: 


Maths operators 

You can use maths operators to add (+), 
subtract (—), divide (/), and multiply (*) numbers. 
For instance: 


Note that the BODMAS (aka PEMDAS) rule 
applies in Python, so b and B are multiplied 
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P You can use 
convert numbers 


to strings and 
vice versa 


esult = a int(b) 
intir esult)} 


together before adding a. You can also add text 
strings together: 


forename = "Joe" 

surname = "Bloggs" 

name = forename + " " + surname 
print(name) 


Note that we added a space between the 
forename and surname in our name string. You 
can’t simply add a number variable to a string, 
however, but you can use the str() method to 
convert a number to a string. 


forename = "Joe" 

number = 90 

name = forename + " " + str(number) 
print(name) 


You can also convert a suitable string (all digits) 
to a number: 


a = 13 

b a "og 

result = a + int(b) 
print(result) 


Lists and loops 

In Python, lists can be used to store variables 
of any type, separated by commas. These can then 
be accessed individually using an index number. 


fruits = ["apple", "banana", "cherry", 


"date"] 
print(fruits[1]) 


NUMBER TYPES 


There are two main types of number in Python: 


integers (whole) and floats (with a decimal point). 
You can convert one type (or a string) to the other 


with the and EAIA) methods. 
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The index number is given in square brackets. 
Since Python starts counting from zero, however, 
the output of this print statement will be ‘banana’. 
You can add extra items to the end of a list using 
the append method: 


fruits = ["apple", "banana", "cherry", 
"date"] 

fruits.append("elderberry") 

fifthfruit = (fruits[4]) 

print(fifthfruit) 


Typically, a list will be used with a for loop, to 
print out a range of values. 


fruits = ["apple", "banana", "cherry", 
"date", "elderberry"] 
for i in range (5): 
print(fruits[i]) 


Note that the lines of code to be looped must be 
indented (by four spaces). This example will print 
out all the fruits in the list, as the for loop iterates 
with values of o to 4 for i. Alternatively, you could 
set the start and end of the range. 


for i in range (1,3): 
print(fruits[i]) 


Since the loop is not executed with the end value 
of 3, this only prints out ‘banana’ and ‘cherry’. 
Loops are useful for a variety of purposes. An 
alternative to a for loop is to use while. This 
iterates the loop so long as the condition is met. 


counter = @ 

while counter < 4: 
print(fruits[counter]) 
counter = counter + 1 


Conditional statements 

When your create programs, you will often 
want to test a condition and have your program 
react differently depending on whether it is true or 
false. For this, we use if and else statements. 


print("What is your name?") 
name = input() 
if name == "Peter Parker": 
print("You are Spider-Man!") 
else: 
print("You are not Spider-Man.") 


NO-INPUT FUNCTION 


Note that not all functions need an input variable, 
in which case it will be defined and called with 
empty brackets. 


Here, we are using the input method to get text 
input from the user. We then use an if statement 
to check whether it matches a particular string - 
note that == is used to check whether values are 
equal. If it does, the following indented line(s) of 
code is executed. If not, the indented line(s) under 
the else statement is executed. 

You can set up a series of conditions by using 
elif (short for ‘else if’) statements. 


if name == "Peter Parker": 
print("You are Spider-Man!") 
elif name == "Bruce Wayne": 
print("You are Batman!") 
else: 
print("You must be a different 
superhero.") 


Functions 

Instead of having to repeat the same block 
of code each time you want to do something, you 
can define it as a function and ‘call’ it any time 
you want to run it. 


def addit(temp): 
a RY AS 2 
print("In Fahrenheit, that is:", f) 


We have defined our function with an 
input variable of temp (it doesn’t matter 
what it’s called). Now, let’s call it from a 
while True: infinite loop. Note that the 
user input text string of c is turned into a 
floating-point number before the function 
is called with addit(c). 


while True: 
print("What is the temperature 
in Celsius?") 
c = float(input()) 
addit(c) 


Note that inputting anything other than 
a number will cause the program to crash. 
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<4 Using conditional 


statements to 
determine what kind 
of superhero you are 


We can use try and except clauses to check it’s a 
number before calling the function: 


while True: 
print("What is the temperature in 
Celsius?") 
try: 
c = float(input()) 
addit(c) 
except ValueError: 
print("This is not a number. Please 
enter a valid number") 


That concludes this introduction to coding 
Python. There are many free online resources and 
courses available to help you learn more. 


[PROJECTS / 
aay 


The Raspberry Pi 
Foundation website has a 
bunch of great projects that 
will help you start writing 
code and get going with 
digital making, 
magpi.cc/projects 


mr 


‘FUTURE LEARN / BE 


The Raspberry Pi Foundation has 
teamed up with FutureLearn to 
provide interactive courses, most 
of which are in Python (and there's 
a great Scratch to Python course). 
The courses are structured to 

last three to four weeks and only 
require a few hours a week to learn. 


Improving Computing Introduction to 
Classroom Practice Through Programming with Scratch 
Action Research pA 


Programming 101: An 
Introduction to Python for 


magpi.cc/futurelearn 
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Build electronic circuits and control them with Python programs 


connect it up to electronic circuits and 
control them using code, also known 
as ‘physical computing’. Components can be 
outputs such as LEDs and buzzers, or inputs such 
as push-buttons and sensors. It is best practice to 
build your circuits with Raspberry Pi powered off. 


a aspberry Pi’s GPIO header enables you to 


Blink an LED 

The ‘Hello world’ of physical computing 
is to make an LED blink, so we’ll start with 

that. Build your LED circuit on the breadboard 

as shown in Figure 1. The LED’s legs are placed 
in different breadboard columns. The longer leg 
is the anode (positive); we connect its column 

to GPIO 14, so we can switch it on and off. The 
shorter leg is connected by a resistor to a long rail 
on the breadboard, which in turn is connected to 
a GND (ground) pin on Raspberry Pi. A resistor is 
essential to limit the current flowing through the 
LED so there is no chance it will burn out. 

Now, in Thonny IDE, let’s create a Python 
program - as in the led.py listing (overleaf) - to 
make the LED turn on and off repeatedly. To 
reduce the need for boilerplate code, we’re using 
the GPIO Zero Python library, which we import 


at the top along with the sleep method from the 
time library. We then create an object named led 
(it could be whatever you like) as an LED set to 
our GPIO 14 pin. 

Finally, we use a while True: infinite loop to 
turn the LED on and off, with a one-second sleep 
delay between each - try altering the delay values 
to slow down or speed up the LED blinking. 


Push to light 

Next, we’ll add an input device to our 
circuit in the form of a push-button switch. We’ll 
then create a program so that the LED only lights 
up when the button is pressed. 

Connect the push-button to the circuit, 
straddling the dip in the middle of the breadboard, 
as shown in Figure 2. On one side, we connect 
one leg to the ground rail; the other leg via a 
resistor to GPIO 23. This means that the pin will 
be high (3.3V) when the button is pressed, but low 
(OV) otherwise. 

Enter the code from the led_button.py listing. 
Note that we import an extra method, Button, 
from GPIO Zero. We then create an object (named 
button here) as a Button for our GPIO 23 pin. 

There are several ways of reading a button 
with GPIO Zero; here, we’re using the is_pressed 
method. In awhile True: infinite loop, we use 
an if conditional statement to check whether the 
button has been pressed, in which case we light 
the LED; if not, the LED is turned off by line of 
code under the else statement. 


Add sound 

Another type of output device you can 
connect is a piezo buzzer, which can make beeping 
noises. Note that there are two types of piezo 
buzzer: active and passive. Here we’re using the 
active type - the circuit and code would need 
altering for a passive one. As in Figure 3, the 


longer, positive leg is connected to GPIO 12. The 
shorter, negative leg is connected to the ground 
rail of the breadboard. 

Enter the code from the buzzer.py listing. In 
the code, we import the Buzzer method from 
GPIO Zero. We then create an object (named buzz 
here) as a Buzzer on GPIO 12. Just as we did when 


We turn the buzzer on and 
off to make it beep 


blinking the LED, we turn the buzzer on and off to 
make it beep - this time in a for loop that iterates 
five times. 


04 Putting it together 

In the doorbell.py code listing, we 
create a primitive doorbell: when the button is 
pressed, the LED blinks and the buzzer beeps 
five times. This time we create a ring function 
for the doorbell ringing and flashing. We then 


assign GPIO Zero’s when_pressed method to 


A Figure 2: We have added a 
push-button switch to our circuit 


MägPi 


Figure 3: The 
complete circuit, 
with an active piezo 
buzzer added 


The 40-pin GPIO (general-purpose input/output) header enables 
a Raspberry Pi computer to be connected to electronic circuits (as 
well as HATs and other add-on boards). There are 26 numbered GPIO 
pins that can be used to switch a connected component on/off, or 
to read a digital input. Other pins include 3V3 (3.3V) and 5V power 
pins and several GND pins for a ground (earth) connection. While the 
layout is the same on all modern Raspberry Pi models, note that on a 
Pi 400 the header is turned upside down. 
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All holes in this row are connected 


eeeee’? eeeee? eeeee?’ eevee’ eevee? 
EEE A) holes in this row are connected 
AAN AN AAAA AASA ANAN ANAA AA SA SA SRN SA AN PR AP APRS SAG r 
DOTO OTOC OCTO T OTOOTO NT OT OTOT ONT OTOT NOT OTOT NT NT NT NT TOT NOT NOT NTN All holes in each column 
e*eeeeeseeeeeeeeeeeeeeeeeeeeeee ee 
ANANA NANANA AAAA NAANA ANA NAANA NANAI NA NAANA AAE NAANA ANADA AE AA AANA NAAA are connected 
A E All holes in each column 
PE CENS @ are connected 


All holes in this row are connected 


*“*—A|l holes in this row are connected 


A breadboard makes it easy to make solderless 
connections between electronic components. 
There are different sizes available, but they 

all work in a similar way. The five holes in 

each column are connected together. Most 
breadboards also have two long ‘rails’ on each 
side - the holes in each rail are connected, 

so they're often used to connect multiple 
components to one power or ground pin. 


PULL UP OR DOWN 


In our button circuit example, the pin is pulled high 
(3.3V, logic 1) when the button isn't pressed, which 
is the default setting for the method in GPIO 


A Once the button is pressed, the function is 
called to blink the LED and sound the buzzer 


call the function when the button is pressed. To 
stop the program then exiting, we use the pause 
method from the signal library. 

If you want to extend this project, you could 


Zero). Pressing the button connects the pin to ground 
and pulls it down to oV (Logic 0). 
Alternatively, you could set the pin to be 


pulled down by default, with 


(eee dah exp). In this case you would wire the other 
leg of the button to 3V3 instead of GND, to pull GPIO 23 


up to high when it's pressed. 
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try using GPIO Zero’s TonalBuzzer method to play 
a rudimentary (and buzzy) tune on the buzzer! 
For more details, see the complete GPIO Zero 
documentation at magpi.cc/gpiozero. 
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> Language: Python 3 


001. from gpiozero import LED 
002. from time import sleep 


003. doorbell.py 

004. led = LED(14) 

005. 

@@6. print("Blinking the LED") > Language: Python 3 

007. 

008. while True: 001. from gpiozero import LED, Button, Buzzer 
009. led.on() 002. from time import sleep 

010. sleep(1) 003. from signal import pause 

011. led.off() 004. 

012. sleep(1) 0905. led = LED(14) 


006. button = Button(23) 
007. buzz = Buzzer(12) 


008. 

led_button.py 008. def ring(): 
iz 010. for i in range(5): 
y 011. buzz.on() 

> Language: Python 3 dae, led OAC) 

008. sleep(0.5) 
001. from gpiozero import LED, Button 009. buzz.off() 
002. 010. led.off() 
003. led = LED(14) 011. sleep(0.5) 
004. button = Button(23) 012. 
005. 008. button.when_pressed = ring 
006. while True: 009. 
007. if button.is_pressed: 010. pause() 
008. led.on() 
009. else: 
010. led.off() 


buzzer.py 


> Language: Python 3 


001. from gpiozero import Buzzer 
002. from time import sleep 


003. 
004. buzz = Buzzer(12) 
005. 
006. print("Beeping the buzzer") 
007. 
@08. for i in range(5): 
009. buzz.on() 
010. sleep(0.5) 
011. buzz.off() 
A The circuit for our basic doorbell, with components on a 012. sleep(@.5) 


breadboard connected to Raspberry Pi's GPIO header 
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[RASPBERRY PI PROJECTS | 


MEDIA CENTRE 


E J 


One of the most popular uses for a Raspberry 
Pi is to use it to play video and audio on 
your TV. There’s even a dedicated media 
player OS for this, LibreELEC (libreelec.tv), 
which incorporates the Kodi media player 
(kodi.tv). It's available under the ‘Media 
Player OS’ category in Raspberry Pi Imager. 
Alternatively, you can install Kodi manually 
within Raspberry Pi OS. 

Either way, you will be able to access files 


well as popular streaming services including 
YouTube, Netflix, BBC iPlayer, and Spotify — 
via official or unofficial add-ons. An optional 
mini remote control makes navigating the 


menus easier. With the addition of a Raspberry 
Pi TV HAT, you can even watch live digital TV 


and record it! 

For more details, check out our Build 
the Ultimate Media Centre feature in issue 
102 (magpi.cc/102). 


on any network-attached storage you have, as 


ith its ability to run an operating 
W system, fast processor, wireless 

connectivity, and a GPIO header for 
connecting electronics, your Raspberry Pi can 
be used in a vast variety of projects. To help 


inspire you, we’ve collected just a few of the more 
popular uses here, but there are so many more. 


RETRO GAMING 


Another classic use for Raspberry Pi is to turn 
it into a retro games machine. The easiest way 
to start playing retro games is to install the 
specialist RetroPie OS (retropie.org.uk), available 
under the ‘Emulation and Game OS’ category in 
Raspberry Pi Imager. RetroPie includes emulation 
software for over 50 classic consoles and 
computers, including NES, SNES, N64, Mega Drive/ 
Genesis, PlayStation 1 and 2, and MAME 
for classic coin-ops. 
While you can simply run RetroPie 
on any TV or monitor and hook up a 
USB joystick, an alternative is to build 
å a \ your own arcade machine based around 
: \ it. Kits are also available, including 
of \ Pimoroni’s Picade (magpi.cc/picade). 
n= N \ For more info on the topic, 

N check out our book, Retro 

. j \ Gaming With Raspberry Pi 
(magpi.cc/retrogaming). 


i TC NE \ | 


a 


a Raspberry Pi is ideal 
iaai for retro gaming. You 
| can even build a mini 
arcade machine such 
as the Picade 


DESKTOP 
PC 


Looking for an 
inexpensive computer 

to work from home? The 
more powerful models 
such as Raspberry Pi 4 
and 400 are viable as a 
desktop PC replacement. 
Raspberry Pi 400 even 


A The Raspberry Pi High Quality Camera 


can be used with different lenses A Awide range of robotics 


kits are available, including 
Pimoroni’s Trilobot 


ROBOTIC 


CAMERA 


While you can connect a standard USB 


webcam to Raspberry Pi, the official Camera Raspberry Pi computers have long has its own integrated 
Module or High Quality Camera offer a lot more been used in homemade robots, thanks keyboard and comes with 
control over your image capturing. Both types to their compact size and processing a mouse, so you're all set 
connect via Raspberry Pi’s CSI (camera serial power, enabling robots to navigate their Many alin sarniices ' 
interface) port. surroundings autonomously, using forteamicollaboration 
The ultra-compact Camera Module V2 sensors such as ultrasonic range-finders are-available: such 
(magpi.cc/camera) comes in two variants: to detect obstacles to avoid. as Google D a csand 
standard and NolR - the latter lacks an IR A mini industry has built up around Slack. Raspberry Pi 
filter, so can be used to capture images at night the creation of Raspberry Pi robotics Os als o enables you 
(with infrared LED illumination). The High kits, including a variety of wheeled foinstall the free and 
Quality Camera has a larger 12.3MP sensor vehicles, robotic arms, and even open-source LibreOffice 
and can be fitted with any C- or CS-mount artificial pets such as the Petoi Bittle productivity suite, which 
camera lens. robot dog. One of the easiest kits for includes apps forwora 
There are many uses for either camera beginners is the CamJam EduKit #3 rocessind spreadsheets 
type, from setting up a wildlife camera trap (magpi.cc/edukit3), which enables you p resent ein il databases i 
to a multi-camera CCTV system. For more to build a two-wheeled robot — you can Sh d moriré: Sè e our Work ' 
ideas, see our Raspberry Pi Camera Guide even use the box as a makeshift chassis. From Home feature in 
(magpi.cc/camerabook) and the photography Alternatively, you can create your issue 93 (magpi.cc/93) 
feature in issue 118 (magpi.cc/118). own custom robot using the wide range j , 


of motors, servos, motor driver boards, 
chassis, and sensors available. See 
our robotics starter guide in issue 120 


H (o) Ki E (magpi.cc/120). M 
AUTOMATION — | Pale 

MIRROR 
With its Wi-Fi and GPIO connectivity, 


Raspberry Pi is ideal for use in a smart home - One of the most popular 
automation system. With the addition of a projects using Raspberry 
relay add-on board, such as the Automation Pi is to make a ‘magic 
HAT (magpi.cc/automationhat), it can enable mirror’, Built using one- 
you to switch lights and many standard 
domestic appliances on and off remotely. Or 
you can add motors and servos to things like 
curtains and blinds to automate them. 


way reflective glass on 
top of a monitor, it can 
display useful information 
such as traffic and 


Everything can be controlled viaa weather as you brush 
web dashboard such as Home Assistant your hair in the morning. 
(home-assistant.io), available as an OS image Fancy building a mini 
to install on Raspberry Pi. To start setting up — magic mirror? Check out 


your smart home, read the three-part tutorial A View and control your smart home appliances our feature in issue 122 
series starting in issue 99 (magpi.cc/99). on the Home Assistant web dashboard (magpi.cc/122). 
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Get Started with 
the Command 
Line book 


To discover more 
useful commands 
and tips for using 
the command 
line on Raspberry 
Pi, check out 

our Conquer the 
Command Line 
book, available 

as a free PDF: 
magpi.cc/ 
commandline 


Get started with 
the command line 


Learn how to use text-based commands in Raspberry Pi OS 


a user-friendly graphical user interface, 
but there are a few limitations to what you 
can do with it. That’s where the command line 
comes in, enabling you to get under the hood 
of the system and unleash the power of text- 
based commands. 

You can access the command line in several 
ways. The simplest is to open the Terminal app 
in Raspberry Pi OS (Figure 1) - either by clicking 
its icon (a black rectangle) in the taskbar or 
opening it from the menu - it’s in the Accessories 
category. Alternatively, you can open a virtual 
console by pressing ALT+CTRL+F1. You’ll also be 
taken straight to the command line if you install 
the Lite version of Raspberry Pi OS, without the 
desktop - or if you opt to ‘Boot to CLI’ in the 
Raspberry Pi Configuration tool. 

Another command way to access the command 
line is to use SSH (Secure Shell) - see the guide 
at magpi.cc/ssh - to access your Raspberry Pi 
remotely from another computer, which is often 
very useful. 


T he standard version of Raspberry Pi OS has 


A Figure 1: You can access the command line from the Terminal 
app, as shown here, or by switching to a virtual console or 
SSHing in from another computer 
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First steps 

When you first access the command line, 
via the Terminal or other means, you will see a 
prompt starting with your username followed by 
‘@’ and the hostname (raspberrypi by default) 
with a colon. For instance: 


magpi@raspberrypi: 


After this, you’ll see the current directory you’re 
in, followed by a ‘S’. You’ll start off in the user’s 
home directory, indicated by ‘~’. 

‘Directory’ is another word for folder and they 
correspond to the ones seen in the File Manager 
on the desktop. So, within your user’s home 
directory (which is located at /home/[username]), 
you’ll find the usual default directories such as 
Downloads and Pictures. To see what’s in the 
current directory, we use the 1s command: 


1s 


This is short for ‘list’? and shows the contents of 
the current directory. 


Navigating directories 
To change to a different directory, the cd 
command is used. For instance: 


cd Downloads 
You will now see ‘~/Downloads’ before the ‘S’ in 
the prompt. Note that to visit another directory in 
your home folder from here, you’ll have to enter 


the full path, such as: 


cd home/magpi/Pictures 


E magpi@raspberrypi: ~ 


Edit Tabs Help 


] ight ny Down Loads 
exampLle.txt 


The command-line prompt 
shows you the user and 
hostname, magpi@raspberrypi, 
followed by the current directory 


/home/magpi/Down Lo 


cat 


Picoamkv 
PictuTfes 
ic Pub Lic 
nloads 
$ cd ~/Pictures 


wn Loads 


example. txt 


as oud 


on high 


Documents/ Downloa 


Or you can use the shorthand of ‘~’ in place of 
‘home/magpi’: 


cd ~/Pictures 


In addition, cd .. takes you up one directory level 
(to the parent directory) while cd - returns you to 
the previous directory. 

If you forget what directory you are in, you can 
find it with: 


pwd 
This stands for ‘print working directory’. 
File manipulation 
Now we can find our way around the file 
system, let’s create a new text file using the touch 
command. In the home directory, enter: 


touch example.txt 


Enter the 1s command and it will show up in the 
list. To edit it, we can use the nano text editor: 


nano example.txt 
Enter a few lines of text (Figure 2) and then close 
it with CTRL+X followed by Y and ENTER to save 
the changes. We can see what’s in a text-based 


file using the cat command. 


cat example.txt 


vales and hills, 


The cat command will reveal 


the contents of a file. If the latter 


are too long, try using the less 
and more commands instead 


VUCUTICNLS/ 


directory. For instance: 


rm example.txt 


for ‘any characters’): 
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swirl.mp4 


If we want to move or copy the file to another 
directory, we use the mv or cp command 
respectively, followed by the path of the target 


cp example.txt ~/Documents 
If you cd to the Documents directory and 1s, you 


will see the copy of the file there. You can delete a 
file using the rm command: 


To search for a file, you can use the find 
command with a selected directory, -name option, 
and filename (which can include the * wildcard 


find /home/magpi -name "e*.txt" 


Temp lates 


Videos 


‘a 


reveals a list of what's in 
the current (or specified) 
directory; subdirectories 
are in dark blue 


The 1s command 


TopTip è 


Auto-complete 


The TAB key is 
your friend on 

the command 

line. Start typing 

a command, file, 
or directory name 
and then press 
TAB to either auto- 
complete it or list 
the possibilities. 
You can also use 
the up and down 
arrows to explore 
your command 
history and quickly 
re-enter previous 
commands. 


<4 Figure 2: The 
nano text editor 
enables you edit 
text-based files, 
including programs 
that you can run 
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magpi@ras 


A Figure 3: You 


can install a wide 
variety of software 
from the command 
line using the APT 
package manager 


TopTip è 


Case-sensitive 


Note that file and 
directory names 
are case-sensitive, 
so entering cd 
downloads won't 
take you into 

the Downloads 
directory, and 

will elicit an error 
unless there is one 
called ‘downloads’. 


Figure 4: You can run 
Python programs 
from the command 
line using the python 
or python3 command 


Making directories 
You can also create a new directory with 
the mkdir command. For instance: 


mkdir Test 
You can delete a directory with the rm command, 
so long as you add the -R switch (short for 
recursive) to delete everything in it: 


rm -R Test 


Be careful with rm command as deleted files are 
not recoverable! 


Installing software 

While there is now an updater tool that 
appears in the taskbar of Raspberry Pi OS desktop 
when software updates are available, you can also 
update your software packages from the command 
line. To download the latest information on the 
configured software packages, enter: 
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sudo apt update 


Here, we are using apt for the APT package 
manager used in Raspberry Pi OS with its update 
command. Note that we need to prefix it with 
sudo, to gain the required superuser privileges - 
you will be asked to enter your password. 

This command is often used before upgrading 
all your software packages: 


sudo apt upgrade 


Or when installing new software. To install 

an example software package (that is in the 

APT repository), we use the sudo apt install 
command with the package name. For instance, to 
install the Claws Mail email client: 


sudo apt install claws-mail 


You will be shown information for it and asked 

if you want to proceed - enter Y to confirm 
(Figure 3). The installation process will then 
begin. Once it’s installed, you will find Claws Mail 
in the desktop applications menu, under Internet. 
Alternatively, you can run it from the command 
line (although it will open in GUI window): 


claws-mail 


To remove a software package, you can use sudo 
apt remove followed by its name. 


Download and install 

Some software may not be available 

from the APT repository, in which 
case you will need to download it 
(making sure it works with the ARM 
architecture for your Raspberry 

Pi) and install it. Instructions will 
typically be given on the website 

for the software. This may involve 
using a curl command to download 
it and run a script to install it, or a 
wget command with the URL for the 
file (typically a zip). You may also be 
asked to clone the GitHub repository 
for a project, such as: 


git clone https://github.com/ 
themagpimag/retro-gaming. git 


Once it has downloaded, you’ll find the retro- 
gaming directory containing subdirectories with 
.py Python files that you can run. For instance: 


cd /retro-gaming/'Part @1 - Racing'/ 
python3 racel.py 


See Figure 4. To stop a program running, you can 
press CTRL+C. 


07 Command-line internet 

You can even perform web searches 
directly from the command line. First, install the 
surfraw tool: 


sudo apt install surfraw 


Surfraw works with helpers called ‘elvi’. To see a 
list of them, enter: 


surfraw -elvi 


Try searching for something with one, using the 
sr command. 


sr duckduckgo Raspberry Pi 


The results will open in a window for the default 
web browser, Chromium. You can, however, also 
view many websites in the command line itself, 
using the w3m text-based web browser. Install 
it with: 


sudo apt install w3m 


1 i Viewing( Sou} <Meather report: Poo 
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Then use it to view a website: 
w3m raspberrypi.com 
For a weather forecast, try: 
w3m wtrr.in/Poole 
You’ll see the forecast for different days, complete 


with ASCII graphics (Figure 5). Other text-friendly 
sites include Google.com and Wikipedia.org. 


Audio and video 

It’s possible to play audio and even video 
from the command line using the mpv media 
player. Download or copy across an MP3 file and 
then play it with: 


mpv example.mp3 


You can sudo apt install the youtube-dl tool and 
then use it download a video from a 
link, or just use the ‘v=’ code at the 
end of the URL for it, such as: 


youtube-dl QIdyTlmdVW8 


This displays a Pico W video. Note 
that it can take quite a while to 
download via the proxy, however. 
Like any other video file, you can 
then use the mpv command with the 
-vo=caca option to play it in super- 
low-res ASCII (Figure 6)! Press Q to 
quit playing the video. m 


«4 Figure 5: It's possible to browse the web from 
the command line. Some sites, such as wttr.in, 
are designed for text-based browsers 


Figure 6: Playing a 
video in ASCII mode 
- can you tell what it 
is yet? 


TopTip è 


Software search 


To search 

for software 
packages in the 
APT repository, 

use apt-cache 
search followed 
by the search 

term. Alternatively, 
download the 
Sources.gz file 
from magpi.cc/ 
aptsourcesbullseye 
and use gunzip 

to extract it for 

the full list of 
software packages. 
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K.G. 
Orphanides 


KG is a writer, 
developer, 

and software 
preservationist. 
They own one 
of those 1990s 
joysticks shaped 
like Giger's Alien 
and can confirm 
that it's not very 
comfy to game with. 


magpi.cc/ 
hauntedowlbear 


| You'll Need 


> Arduino IDE 2.0.2 
or above 
arduino.cc/en/ 
software 


> PicoGamepad 
library 
magpi.cc/ 
picogamepad 


> DBg joystick 
INO file 
magpi.cc/ 
picoconverter 


> A DBg joystick 


> Serial port (male) 


Build a DB9 to USB 
joystick converter 


Connect retro joysticks to a modern PC over USB using Raspberry Pi Pico 


e’ll be using Raspberry Pi Pico to convert 
W input from a 9-pin DB-9 joystick, 

via male D-sub port, into USB input 
recognised by any modern PC. We refer to these 
9-pin D-sub connectors as ‘DB-9’ - because it 
is the most widely used term - but they are more 
correctly called DE-9 connectors, which you’ll also 
find used. It’s the same physical connection as an 
RS232 serial port and a D-sub port, which makes 
for a long list of terms used interchangeably. 

We’ll be programming Raspberry Pi Pico using 
the cross-platform Arduino IDE and Arduino’s 
Mbed OS for RP2040 boards. This gives us access 
to Arduino’s mature and very capable HID (human 
interface device) handling. 

The project uses code and components 

created by RealRobots and NickZero. This 

tutorial assumes that you’ll be programming 

Pico from a Debian-based Linux system such as 
Raspberry Pi OS. However, all the hardware and 
microcontroller programming elements are entirely 
platform-agnostic. 


Prepare your hardware 

We built this project on breadboard. If 
you want to do the same, it’s a good idea to 
use a Serial port with a screw terminal block 
- both open (magpi.cc/dbusblock) and closed 
(magpi.cc/dbgblock) designs are available. Attach 
Raspberry Pi Pico - with headers - to a small 
breadboard. We like Monk Makes’ Breadboard 
for Pico (magpi.cc/breadboardpico) because of 
its built-in GPIO cheat sheet, but any breadboard 
works perfectly well. See step 12 if you want to 
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make the project a little more permanent with a 
case and soldered connections to a standard male 
D-sub port (magpi.cc/connectorsubd). 


Connect the DB-9 port 

You’ll need six male-male DuPont jumper 
cables to connect the port. We don’t have any 
specific feature requirements in our breadboard 
build, so you can choose whichever of Raspberry 
Pi Pico’s GPIO pins you fancy. If you’re encasing 
the build in any way, pick pins that won’t get in 
your way. 

As you’ll see in our wiring diagram, we’ve 
connected serial port pin 1 (up) to GPIO2, serial pin 
2 (down) to GPIO 3, serial pin 3 (left) to GPIO 4, 
serial 4 (right) to GPIO 5, serial port pin 6 (fire) 
to GPIO 6, and serial pin 8 (ground) to the ground 
connection on Pico’s third physical pin. Finally, 
plug your joystick’s connector into the port. 


Arduine RasphereyPi Pics 
. @ ) &) & [| (=) [&) pe 
1 =] a] [fa 
=z > 
ag ; 
(amg E 
= f 
‘ 4 Our favourite 

ae a) e) [e) joystick tester 
== is jstest-gtk 


It is available 
from most 
Linux distros’ 
repositories 


The pin designations silk- 
screened onto most serial/ 
D-sub ports don't apply to 
joystick connections, and 
can safely be ignored 


To keep everything 
consistent, we've retained 
the same wire colours here 
as in NickZero’s design 


Install the Arduino IDE 

Download the latest Arduino IDE from 
magpi.cc/arduinoide or, if you’re running 
Raspberry Pi OS: 


sudo apt install arduino 

If you’re running the IDE on Linux, including 
Raspberry Pi OS, you’ll need to download and 
run as root the post-install script from 
magpi.cc/postinstallsh to create a UDEV rule 
allowing the IDE to write to Pico, thus: 


sudo sh post_install.sh 


Next, add your username to the dialout group 
for serial port access: 


sudo adduser YourUsername dialout 


Add the PicoGamepad library 

Download RealRobots’ Raspberry Pi Pico 
Gamepad/Joystick Library as a ZIP file from 
magpi.cc/picogamepad. Open the Arduino IDE 
and, from the top menu bar, go to Sketch > 
Include Library > Add .ZIP Library, and browse 
to PicoGamepad-master.zip. To make sure that 
it’s been added correctly, go to Files > Examples 
and look for PicoGamePad under Examples from 
Custom Libraries. 


s.... s... 
s...) s.. .. 


ener 
s.. .. 


eee eee eee ee ee iG 


Customise your DB9 
converter code 
Download NickZero’s DB9 converter code as 
a text file from magpi.cc/picoconverter or 
our DB9-joystick.ino from our repository at 


m Add the GPIO numbers for 
your buttons Ø 


magpi.cc/usbtodbg, and open it in Arduino IDE. 
Where PIN_BTN_o through 4 are defined at the 
beginning of a script, add the GPIO numbers 

for your fire, up, down, left, and right buttons. 
o is fire and the directional controls start at 1. 
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Vv 


Get the right 
pinout 


Different 
computers’ 
joystick pinouts 
differ. See 
magpi.cc/ 
degjoystick for 
examples and 
modding guides. 


We built our adapter 
on breadboard 
using a D-sub port 
with convenient 
screw terminals 
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A Our retro joystick 
is ideal for playing 
modern C64 games 
like Sarah Jane 
Avory's Zeta Wing 
(magpi.cc/zetawing) 


P The joystick is 
immediately 
recognised by the 
Vice emulator: all 
you have to do is 
assign it. You'll want 
to configure it as 
Joystick 2 for most 
games, but there's a 
keyboard shortcut to 
swap them 


By default, up, down, left, and right are configured 
as joystick directions defined on X and Y axes. 
However, you can reconfigure them to fire buttons 
instead or as well. 


Get ready to write 

Press and hold the BOOTSEL button on Pico 
as you connect it to your computer. You’ll have to 
do this every time you wish to write a sketch from 
the Arduino to the microcontroller. In the Arduino 
IDE, from the top bar, open Tools > Boards 
Manager and search for ‘pico’. Select Arduino 
Mbed OS RP2040 Boards by Arduino, select the 
most recent version (3.3.0 at time of writing) from 
the pull-down, and click Install. Close Boards 
Manager by selecting it from from the menu again. 
Make sure Tools > Boards > Arduino Mbed OS 


+ Moe 


+ Moine matn parenn. 
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RP2040 Boards > Raspberry Pi Pico is selected and 
that Tools > Port is /dev/ttySo. 


07 Upload now 
Click the upload button, a right-facing 
arrow, in the quick bar at the top of the IDE. If all 
goes well, the Output pane at the bottom of the 
window should show that the program has been 
compiled and loaded into flash. 

If you want extra detail in your Output pane, 
open File > Preferences and select Show verbose 
output for compile and upload time. 

If you’re running Linux and getting a mysterious 
‘error occurred while uploading the sketch’, make 
sure that you’ve run the post_install.sh script 
from step 3. 


Test your joystick 
Time to install a joystick tester. On 
Raspberry Pi OS and other Debian-based Linux 
distros, open a command-line terminal and type: 
sudo apt install jstest-gtk. 
Run jstest-gtk and you should see an Arduino 
RaspberryPi Pico associated with /dev/input/jso 


m Test your stick and button 
and see what lights up Ø 


listed. Double-click this to open the button testing 
screen. Now test your stick and button and see 
what lights up. Alternatively, visit 
gamepad-tester.com for a platform-agnostic 
HTMLS joystick tester. 


Modern mappings for 

modern games 
Now that your joystick’s working, you can 
absolutely play Minecraft with this setup - for 
a given value of ‘play’. We installed AntiMicroX 
as a Flatpak on our Linux gaming system and 
mapped our joystick axes to WASD and fire to our 
left mouse button. So you can move forwards, 
backwards, strafe, and break blocks. Turning? Who 
needs it? But modern games aren’t really what 
we’re going for here. 


H 


Retro emulation time 

Install an emulator. C64 Forever and 
its version of Vice (c64forever.com) are free on 
Windows and you can use its licensed system 
ROMs with Vice on other operating systems. The 
Flatpak version (magpi.cc/flathubvice) is an 
easy option for Linux. You can find our guide to 
running Vice on Raspberry Pi in The MagPi 102 
(magpi.cc/102) and find new C64 games to buy 
and download for free at magpi.cc/itchc64. 

Open Vice’s C64 emulator, go to Preferences > 

Settings > Input devices > Joystick and select the 
Arduino Raspberry Pi Pico. Remember, the C64’s 
primary joystick was Joystick 2 - press ALT+J to 
swap at any time. Go to File > Smart attach, select 
your game’s file, then its PRG in the pane on the 
right. Wait for it to load, then type RUN. 


Extra buttons 

If you’re using a Competition Pro joystick 
like ours, a modern clone, or most standard 
joysticks from the C64 through the Amiga era, 
all the fire buttons are linked to pin 6, but you 
can physically mod your joystick to give you 
two separate fire buttons. Some two-button 
configurations may also require the addition of 
resistors to pins 9 (fire 2) and 7 (+5V). You’ll 
have to modify the converter script accordingly to 
define and invoke fire 2, for example by creating 
PIN_BTN_5 and supplementing the ‘Button 
on pin’ and ‘Fire Button’ sections of the code 
accordingly. You can also find contemporary two- 
button joysticks, but they’re relatively unusual. 


Tidying up 

NickZero’s make includes STL files for a 
case with built-in switch for a fully soldered and 
encased DB9-to-USB peripheral. However, you’ ll 
probably need to iterate on the Thingiverse files 
provided at magpi.cc/picoconverterfiles to make 
it work for your 3D printer and components. 
When we had one printed by a service, we found 


that the hole for the D-sub port was too small for 


our standard male 9-pin port, while the switch 
designed to allow the on-board button to be 


pressed was too wide for the hole it’s supposed to 
slot through. The overall design is great: the case 


fits together nicely and looks professional, so is 
well worth tweaking if you have a 3D printer and 
the patience to experiment. 


A Controler Mapoing Quick Set 1 Names Pret 


AntiMicroX is ideal for mapping your retro joystick to 
whatever preposterous purpose you may put it to, from 
controlling your mouse cursor to (sort of) playing Minecraft 


Build a DBg to USB joystick converter 


+ 


+ 


Our Competition 

Pro might not feel 

as smooth as a 
modern pad with 
analogue sticks, but 
it's absolutely the 
right tool for our retro 
gaming needs 


Top Tip 


AntiPlcrox 


If you're using 
your joystick 

on a Raspberry 

Pi computer, 
AntiMicrox 

is ready to 

install from the 
repository with 
sudo apt install 
antimicrox. 
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PJ Evans 


PJ is a writer, 
software engineer 
and rarely without a 
soldering iron in- 
hand. He's worried 
his fish are watching 
him back. 


mastodon. 
social/@ 
mrpjevans 


| You'll Need 


> Entaniya 
Waterproof Case 
for Camera Module 
magpi.cc/ 
waterproofcase 


» 100cm cable 
magpi.cc/ 
longribboncable 


» Camera Module 2 
magpi.cc/ 
cameramodule 


Watch your fish 
with a Raspberry 
Pı camera 


Remote video monitoring is easy with Raspberry Pi. Here, we use a 
waterproof camera case to get a unique view of some aquatic friends 


waterproof case for the Raspberry Pi 

Camera Module. This case protects the 
Camera Module without distorting the image. 
With it, we can submerge a camera into the 
depths of an aquarium and keep an eye on our 
fishy pals by streaming video. If that doesn’t 
appeal, you can adapt this tutorial to be able to 
monitor a video stream of anything you like, 
whether it be indoors or outdoors. Combined with 
Home Assistant, you can soon be monitoring your 
cameras from anywhere in the world. 


T his tutorial was inspired by the Entaniya 


Prepare you Raspberry Pi 

For the best picture quality, a Raspberry Pi 
4, is the perfect choice. That said, you’ll get good 
results from a Raspberry Pi Zero 2 W as well, and 
it’ll be easier to install. Whichever you choose, 
we recommend using the Raspberry Pi Lite 


A Some assembly is required. The kit is straightforward to 
build and creates a watertight space for your camera 
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(Legacy) OS. The project uses the raspivid tool, 
support for which is limited in the latest version 
of the OS. The Legacy ‘Buster’ image still has 

full compatibility. You can find it in Raspberry Pi 
Imager under ‘Raspberry Pi OS (Other)’. Set up 
Wi-Fi, and make sure everything is up-to-date 
with sudo apt -y update && sudo apt -y upgrade. 


Install and configure your camera 

With your Raspberry Pi disconnected from 
power, install the ribbon cable and Camera Module 
(we’ll get to the case later). The cable will work 
either way around; however, the blue side (the one 
without the exposed contacts) needs to be against 
the black clip at each end. Find the connector on 
your Raspberry Pi marked ‘CAMERA’, raise the 
clip, gently insert the cable, then press the clip 
down again. Repeat for the Camera Module. Power 
up your Raspberry Pi and, at the command line, 
run sudo raspi-config. Go to ‘Interfaces’, then 
‘Camera’, and choose ‘Enable’. You’ll then need 
to reboot. 


Test your setup 

We've set up the camera first to check 
everything is working before we put it ina 
waterproof case. After the reboot, run the 
following command: 


hS 


The case floats, so some 
ingenuity is required to 


keep it in place 


raspivid -f 


All being well, you should see video from the 
camera on-screen for five seconds. If you don’t, 
check if the cable is inserted correctly, and that 


m You can adapt this tutorial 
to be able to monitor a 
video stream of anything 
you like @ 


you’ve enabled the camera, as in Step 2. Now 
check the orientation. With the cable pointing up 
from the module, is the image the right way up? If 
not, you can switch it using this command: 


v412-ctl --set-ctrl horizontal_flip=1 


Finally, check everything is in focus and adjust the 
camera accordingly. 


Install dependencies 

We’re going to be using a real-time video 
streaming server to watch our fish (or whatever 
you’ve decided). This requires some supporting 
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TopTip è 


The waterproof 


case keeps your Go HQ 
Camera Module 
safe and dry without Although the 


case is for the 
original camera 
form-factor, 

the tutorial will 
work with newer 
HQ Cameras. 


missing the action 


software so we can build and run it, so now is the 
time to get everything ready. Make sure you have 
run sudo apt -y update && sudo apt -y upgrade, 
as in Step 1. Enter the following command: 


sudo apt install cmake liblog4cpp5-dev 
libv4l-dev git 


This will install everything you need. 


Build the video streaming server 

Unfortunately, the streaming server is not 
available on APT, so we have to build it ourselves. 
This is straightforward, providing you enter the 
commands below carefully and in order. From the 
command line, enter the following: 


cd 

git clone https://github.com/mpromonet/ 
v4l2rtspserver.git 

cd v4l2rtspserver 

cmake . 

make 

sudo make install 


This will download the source code, prepare a 
configuration for Raspberry Pi, and then compile 
the software and install it. Once installed, you 
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Warning! 
Water 


Water can damage 
low-voltage electrical 
equipment. Water with 
mains-voltage electricity 
can be deadly. 


magpi.cc/ 
electricalsafety 


TopTip è 


Stream better 


It's good to get 

to know the 
command-line 
options for 
v4lzrtspserver as 
you can adjust the 
stream size, frame 
rate, and quality. 


Y The assembled case 
Now the camera is 
protected from the 
elements, whether 
it be in an aquarium 
or outdoors 


can then delete the v4lartspserver directory if 
you wish. 


Test your video stream 

Before we start filming the fish, let’s test 
if the video stream itself is working. On another 
computer, install VLC (videolan.org). This is a 
multi-purpose video playback application that 
supports the server we are using. From your 
Raspberry Pi, run this command: 


v4l2rtspserver -W 640 -H 480 -F 15 -P 8554 
/dev/videoð 


You should see some text output on the screen. On 
the other computer, open VLC, click on ‘File’ then 
‘Open network’. In the URL box, enter: 


rtsp://<ip-address>:8554/unicast 


Replace <ip-address> with the IP address of your 
Raspberry Pi (use ip addr to find it). Click ‘Open’ 
and wait a few seconds. You will see a stream from 
the camera. 


07 Start at boot 
Now we have a working video stream, we 
need to make sure it always starts at boot time. 
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A Once your stream is running, you can add it to Home 
Assistant so you keep an eye on our fish anywhere 


A service file already exists for the server; we just 
need to change one line. Open the file with: 


sudo nano /lib/systemd/system/ 
v4lartspserver.service 


Find the line starting with ‘ExecStart’ and change 
it so it reads as follows: 


ExecStart=/usr/local/bin/v4l2rtspserver -W 
640 -H 480 -F 15 -P 8554 /dev/video@ 


Check it’s exactly as written here, then use 
CTRL+X followed by Y and ENTER to save the file 
and close the editor. Now enable the service: 


sudo systemctl enable v4l2rtspserver 


To test it, reboot, and then use VLC again to open 
the stream. 


Mount the camera in the case 

Let’s turn our attention to the waterproof 
case. Following the included instructions, separate 
the base from the outer cover. Now open the 
supplied desiccant, and place both leaves in the 
centre of the base in the space provided. If any 
moisture gets in, these will absorb it, protecting 
your camera. Screw in the adapter mount for the 
camera, then carefully thread the connected ribbon 
cable through the slot. Finally, mount the camera 
to the adapter, being careful not to over-tighten 
the screws. Make sure the cable is fitted correctly. 


Install the camera cover 

Locate the rubber O-ring and place it on 
the base so it sits in the ridge provided. Take the 
clear cover and place it over the base, and secure it 
with the M3 nuts and bolts. We recommend going 
across each one rather than around the base; it will 
ensure a more even fit. Again, be careful not to 
over-tighten the screws. Snap the outer cover over 
the clear cover. Take the small rubber grommet 
and, very carefully, feed the ribbon cable through, 
threading it through the grommet until it meets 
the base. Insert in the slot and secure with the 
metal plate. You now have a waterproof case. 


Mount your waterproof camera 

What happens next will require some 
initiative. Depending on what it is you want to 
monitor, this determines how you will set things 
up. For our aquarium project, you can either attach 
some rubber ‘suckers’ to keep the camera in place, 
or find a suitable place to rest it on the substrate 
or sand. For outdoor use, Entaniya sells a wall- 
mount adapter to make things easier. Either way, 


m if your interest lies more 
with remote monitoring, try 
adding presence detection 
or facial recognition to 
Home Assistant alongside 
the video feeds Ø 


you still need to consider how to get the ribbon 
cable inside or out of the tank and to a safely 
installed Raspberry Pi. Your biggest restriction is 
the length of the cable itself. 


Add to Home Assistant 

One of the best ways of utilising this 
monitoring solution is Home Assistant, the 
popular home automation operating system. 
Luckily, support for a remote camera like this is 
baked right into the service. To add the stream 
in, you’ll need to be able to access and edit the 
configuration.yaml file. Add the following text: 


camera: 
- platform: ffmpeg 
name: FishCam 
input: rtsp://<ip-address>:8554/unicast 


As before, change <ip-address> to your Raspberry 
Pi’s address. Now restart Home Assistant. In your 
dashboard you can now add a ‘Picture Glance’ card 
using the newly created ‘FishCam’ entity. Now 
your fish can be viewed wherever you can access 
Home Assistant. 


Next steps 

There are many ways you can build on 
this project. If you’ve installed a FishCam in your 
aquarium, there’s lots more to do. Monitor the 
aquarium temperature with a 1-Wire temperature 
sensor and send alarms when things go awry. Or, 
use a flow sensor to keep an eye on the pump. If 
your interest lies more with remote monitoring, 
try adding presence detection or facial recognition 
to Home Assistant alongside the video feeds. 
Motion detection can be used to trigger recording 
or alerts. Outdoor cameras can be used to keep 
an eye on your backyard chickens or who’s at the 
front door. As ever, it’s over to you. Hl 


The author would like to acknowledge siytek.com, 
whose excellent video streaming tutorial informed 
this piece. 
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A This little fish came 


a little close for 
comfort. Getting a 
clear image may take 
a few goes to get the 
best results 


TopTip è 


Take a 
different view 


The case is 
compatible with 
a number of 
alternative lenses. 
Why not try a 
fish-eye lens for 
a great view of 
the aquarium? 
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Toby Roberts 


Toby used to make 
secret things for the 
police. Now he is 
Maker in Residence 
at Raspberry Pi. 
Laser cutting and 
3D printing are his 
favourites. Free 
merch hoarder! 


raspberrypi.com/ 
tutorials 


I You'll Need 


> Raspberry Pi 
(any model) 


> USB-C power 
supply unit (PSU) 


> microSD card 
> HDMI cable 


> Monitor, TV, or 
other suitable 
display 


How to use a 
Raspberry P1 


in kiosk mode 


Create bespoke full-screen digital signage and interactive 
experiences for users on Raspberry Pi with kiosk mode 


information or a specific experience, 
while preventing access to any other 
activities on the device. They are often found in 
airports, shops, hospitals, cafés, and museums 
- any location where people need easy access to 
information or services like timetables, waiting 
times, product information, directions, self 
check-in machines, and so on. 
Kiosk mode on your Raspberry Pi allows 
you to boot straight into a full-screen web 
page or an application without using the 
desktop environment. It’s the foundation for 
many different projects where you want to 
display information for a dedicated interaction 
with a user. 


K iosks are designed to offer users specific 


Choosing the right Raspberry Pi 

and accessories 
Kiosk mode will work on any Raspberry Pi. For 
this tutorial, we’ll be using a Raspberry Pi 4, so 
you will need a USB-C power supply and a micro- 
HDMI-to-standard-HDMI cable. Older models will 
require a micro USB power supply and a standard- 
HDMI-to-HDMI cable instead. 
Kiosks are left powered for long periods of time, 
so it’s important to have a good-quality power 
supply for your Raspberry Pi. We recommend the 
official USB-C and micro USB power supplies, as 
they are designed to provide a consistent +5.1V 
with captive (attached) USB cables. Don’t be 
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tempted to use an old spare phone charger and 
cable you may have lying around, as they may not 
provide sufficiently reliable power. 


Display and setup computer 

The type of display you require depends 
very much on your intended project. A TV or 
monitor with HDMI input is all that’s required for 
this guide, but you might find you need something 
more specific for an interactive experience or a 
more compact display. For example, the Raspberry 
Pi Touch Display is perfect for information 
dashboards, such as you might use in a Raspberry 
Pi weather station. 

For the initial microSD card setup, you’ll also 
need another computer connected to your network. 
We'll refer to this as ‘your usual computer’, to 
distinguish it from the Raspberry Pi computer that 
you are setting up in kiosk mode. We’re going 
to be accessing and controlling Raspberry Pi via 
Wi-Fi from this computer, so there is no need for 
an additional keyboard and mouse to be attached 
to your Raspberry Pi. 


Installing Raspberry Pi OS (32-bit) 

We're going to use Raspberry Pi Imager to 
install Raspberry Pi OS (32-bit) onto the microSD 
card. Raspberry Pi Imager is available for free for 
Windows, macOS, Ubuntu for x86, and Raspberry 


Raspberry Pi is set to 
boot up and start running 
automatically and is 
locked down to prevent 


unwanted hands from 
interfering with our display 


Pi OS. Download it to your usual computer 
from magpi.cc/imager. 

Connect your microSD card to your usual 
computer using an SD card adapter if you need 
one. We recommend a minimum storage size of 
16GB. Open Raspberry Pi Imager, click CHOOSE 
OS, and select Raspberry Pi OS (32-bit), which is 
the smaller-sized Raspberry Pi OS that includes 
a desktop environment but doesn’t come 
with unnecessary additional applications for 
this project. 

Press CTRL+SHIFT+X to bring up the Raspberry 
Pi Imager advanced menu, or click the advanced 
menu cogwheel button in the bottom-right corner: 
Set a host name of your choice; we’re using 
kioskpi here. Check the ‘Enable SSH (Secure Shell)’ 
box and set a username and password. You’ll need 
these details to access your Raspberry Pi later, so 
be sure to make a secure note of them. Configure 
your wireless LAN by checking the box, and replace 
‘XXXXXXX’ with your own SSID (network name) 
and password. 

Click SAVE to close the advanced menu, and 
finally select WRITE to start the process of writing 
the operating system to the microSD card, which 
will take a few minutes to complete. 


Starting and updating your 

Raspberry Pi 
Insert your microSD card into your Raspberry Pi 
and connect it to the mains power via a USB-C 
power supply unit. Your Raspberry Pi will now 
boot for the first time and will connect to your 
Wi-Fi network automatically, as we have already 
given it all the credentials it needs. 


Connect to your Raspberry Pi 
via SSH 
Open a terminal session on your usual computer 
and run the following to access your Raspberry 
Pi via SSH, replacing ‘pi’ and ‘kioskpi’ with the 
username and hostname you chose. 


ssh pi@kioskpi.local 


The first time you do this, confirm that you 
want to connect, answer ‘yes’ and press RETURN. 
When asked, enter the password you created in 
Raspberry Pi Imager (in Step 3). 

It’s best practice to run an update task for a 
fresh installation of Raspberry Pi OS, and it’s 


m Kiosks are left powered for 
long periods of time @ 


something that you should do regularly. You want 
to ensure the device is running with the very latest 
versions of all programs and security. Run the 
following two commands, typing Y and hitting 
ENTER when prompted to continue: 


sudo apt update 
sudo apt full-upgrade 


Reboot your device to allow any changes to 
take effect: 


sudo reboot 


Now that your Raspberry Pi is fully updated and 
ready to go, log back in before moving on. 


Our Raspberry Pi displays 
information on this monitor 
that can be left in place 
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Stop the 
service 


The following 
command will 
stop the service if 
you ever need to 
close the browser: 


sudo 
systemctl 
stop 
kiosk.service 
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Setting up kiosk mode 
You only need two additional packages for 
kiosk mode to work: 
-+ unclutter - removes the mouse pointer from 
your display 
-+ xdotool - simulates keyboard and mouse 
activity 
To install these programs, just run the 
following command: 


sudo apt install xdotool unclutter 


In order to make sure your Raspberry Pi boots 
straight into the desktop environment when it’s 
powered up without the need to log in, use the 
software configuration tool: 


sudo raspi-config 


avigate through the menu, selecting ‘1 
System Options’, then ‘S5 Boot / Auto Login’, 
and finally ‘B4 Desktop Autologin - Desktop 
GUI, automatically logged in as ‘pi’ user’. Press 
ENTER and click Finish to save this setting. You 
will be prompted to reboot again; log back in 
once you have done this. If you haven’t already 
connected an HDMI display to your Raspberry Pi, 
now is the time to do so. Once you have rebooted 
your Raspberry Pi, you should see the desktop 
environment on your display. 


07 Create the shell script 
Next, you need to create a small script to 
tell your Raspberry Pi what to present in kiosk 
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mode and how to present it. For this tutorial, we 
want to display both the Raspberry Pi and the 
Greenwich Mean Time web pages, switching back 
and forth between the two sites. First we’re going 
to use nano, a text editor, to create our script: 


sudo nano /home/pi/kiosk.sh 


Type out, or copy and paste, the kiosk.sh code 
into your file. Press CTRL+X, then Y, and finally 
ENTER to save the new file. 


Create a service 

In order to get Raspberry Pi to run our 
kiosk whenever it is powered on, we need to 
create a service. Use the text editor again to 
create another file to do this: 


sudo nano /lib/systemd/system/kiosk.service 


Type out the kiosk.service code, or copy and 
paste it into the file. You can see that the service 


m To run our kiosk whenever 
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starts our newly created kiosk.sh bash script. Hit 
CTRL+X, then Y, and ENTER again to save the 
file. Run the following command to enable our 
new service: 


sudo systemctl enable kiosk.service 


Either reboot or run the following to start 
the service: 


sudo systemctl start kiosk.service 


Adding security and fail-safe 
functionality 
By their very nature, kiosk mode devices are often 
left to run unattended for long periods of time. 


They are frequently turned off and on again at 
the mains, and left in public places, making them 
vulnerable to unwanted attention or interference. 
None of this is conducive to a reliable long-term 
kiosk mode installation, and kiosks can also be 
seen as a potential target for hackers. Whilst it’s 
not realistic to make them 100% secure, there are 
a number of things we can do to protect them. 


Disable ports 

As this project currently stands, simply 
plugging a keyboard and mouse into the USB 
ports on our Raspberry Pi would give an attacker 
full control of our device, and potentially others 
on the network. Access to the Ethernet port is 
another weakness. The simplest way to defend 
against this is to disable all the unused ports. The 
following command will disable all USB ports: 


echo '1-1' | sudo tee /sys/bus/usb/drivers/ 
usb/unbind 


To reverse this to enable the ports again, run 
the following: 


echo '1-1' | sudo tee /sys/bus/usb/drivers/ 
usb/bind 


In order to disable the Ethernet port, enter the 
following command: 


sudo ifconfig eth@ down 
Reversing this with: 


sudo ifconfig eth@ up 


Update rc.local 

These disable commands are not 
persistent, so when power is cycled the ports will, 
by default, be enabled again. The easiest way to 
disable them every time the device is powered on 
is to add to the /etc/rc.local file. The contents of 
this file are run at the end of every boot process, 
so it is ideal for our purpose. Edit the file using 
the following command: 


sudo nano /etc/rc.local 


Add the disable commands above the exit @ 


line and then hit CTRL+X, Y, and ENTER to save. 


The file should now look like this: 


# By default this script does nothing. 


echo '1-1' | sudo tee /sys/bus/usb/drivers/ 


usb/unbind 


sudo ifconfig eth@ down 


exit @ 


Each time your Raspberry Pi boots up, the USB 


and Ethernet ports will now be disabled. 


Turn off Bluetooth 

By default, Raspberry Pi has Bluetooth 
turned on. For this tutorial, it is not needed, 
and as such it’s a possible avenue of attack you 
can do without. To turn it off, simply edit the 
/boot/config.txt file. 


sudo nano /boot/config.txt 
Add the following line to the bottom of the file: 


dtoverlay=disable-bt 


o Text console, requiring user ti 


in 
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kiosk.sh 


DOWNLOAD 
THE FULL CODE: 


> Language: Bash 


© magpi.cc/github 


001. 
002. 
003. 
004. 
005. 
006. 
007. 
008. 
009. 


010. 


011. 
012. 


013. 
014. 
015. 
016. 
017. 


#!/bin/bash 


xset s noblank 
xset s off 
xset -dpms 


unclutter -idle 0.5 -root & 


sed -i 's/"exited_cleanly":false/"exited_cleanly":true/' 
/home/pi/.config/chromium/Default/Preferences 
sed -i 's/"exit_type":"Crashed"/"exit_type":"Normal"/' / 
home/pi/.config/chromium/Default/Preferences 


/usr/bin/chromium-browser --noerrdialogs 
--disable-infobars --kiosk https://www.raspberrypi.com/ 
https://time.is/London & 


while true; do 
xdotool keydown ctr1+Tab; xdotool keyup ctr1+Tab; 
sleep 10 

done 


Press CTRL+X, Y, and ENTER to save, then 
reboot. Bluetooth will be disabled permanently. 
Simply remove the line you added to enable 
Bluetooth again if needed. 


Set up SSH using keys rather 
than a password 
Until now, connecting to our Raspberry Pi has 
been via SSH using a password. An added level 
of security is provided by connecting using pre- 
generated private-public RSA keys, and removing 
the ability to log in via username and password 
altogether. A private key is kept on your usual 
computer, the one you wish to use to connect 
to your kiosk, and a public key is kept locally 
on your Raspberry Pi. The two together provide 
a far better means of secure connection than a 
username and password. To create keys, open 
a terminal on your usual computer and run 
the following: 


ssh-keygen 
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Accepting the defaults when prompted will 
create a private and a public key. The location of 
these saved files is also given. 

The id_rsa key is your private key; do not 
share it or back it up anywhere inappropriately. It 
will be held locally on your usual computer. The 
id_rsa.pub is the public key, and now needs to 
be transferred to your Raspberry Pi. SSH back in 
to the device, and create the following required 
folder and file ready to copy and paste in the 
contents of the newly created id_rsa.pub key: 


cd 
mkdir .ssh 
cd .ssh 


nano authorized_keys 


The first two lines make a normally hidden 
folder called .ssh in your home folder. Then 
you navigate into the new folder and create a 
file called authorized_keys using the nano text 
editor. Copy and paste the contents of id_rsa.pub 
from your usual computer into this file, then hit 
CTRL+X, Y, and ENTER to save it. 

Reboot your Raspberry Pi and SSH back in. If 
everything works as expected, you will no longer 
be prompted to enter a password, and we can now 
disable password access completely by editing the 
/etc/ssh/sshd_config file: 


sudo nano /etc/ssh/sshd_config 


Find the line in the file that reads 
#PasswordAuthentication yes. Uncomment it by 
removing the # to enable the line, and change yes 
to no, so it looks like this: 


# To disable tunneled clear text passwords, 
change to no here! 

PasswordAuthentication no 

#PermitEmptyPasswords no 


Press CTRL+X, Y, and ENTER to save the file, 
and you are done. 


SD card read-only mode 

Computers do not like being shut down 
by simply being unplugged; that is likely to 
result in a system file corruption at some point. 


Furthermore, our operating system is stored ona 
microSD card, which may eventually fail if used 
24/7 for long periods of time. To reduce these 
risks, you can make your microSD card read-only. 
This should be done as the final process when 
building in kiosk mode. 

Head back into the raspi-config setting with 
the following command: 


sudo raspi-config 
Navigate through the menu system as follows: 


Select ‘4 Performance options’ > ‘P3 Overlay 
File System’. Confirm you’d like the overlay file 
system to be enabled. Confirm you’d like the boot 
partition to be write-protected. Once done, click 
Finish and confirm you want to reboot. 

This whole process may take a few minutes 
to complete. 

If you need to enable access again to carry 
out an update or adjust your scripts, SSH back 


m Computers do not like 
being shut down by simply 
being unplugged Ø 


into your device and run this command to allow 
access temporarily: 


sudo mount -o remount,rw /boot 
You can now carry out any work required. 


Another reboot will revert your microSD card back 
to a read-only state. 
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kiosk.service 


> Language: Bash 


001. 
002. 
003. 
004. 
005. 
006. 
007. 
008. 


009. 
010. 


011. 
012. 
013. 
014. 
015. 
016. 


[Unit] 
Description=Chromium Kiosk 
Wants=graphical.target 
After=graphical.target 


[Service] 
Environment=DISPLAY=:0.0 
Environment= 
XAUTHORITY=/home/pi/.Xauthority 
Type=simple 

ExecStart= 

/bin/bash /home/pi/kiosk.sh 
Restart=on-abort 

User=pi 

Group=pi 


[Install] 
WantedBy=sraphical.target 


Understanding kiosk.sh 


Let's break the kiosk.sh script down into its component parts in order to 
understand what it does: 


Taking kiosk mode further 

This guide explores the basics of setting 
up a simple web page viewer in kiosk mode. 
Building on this might take you on a journey to 
more complex projects, such as a CCTV viewing 
station, a home automation system, or perhaps 
the ultimate in kiosk mode projects: a magic 
mirror (magicmirror.builders). This project was 
the winner in The MagPi magazine’s 50th issue 
celebration feature, as voted by the Raspberry Pi 
community (magpi.cc/50). I 


#!/bin/bash - This instructs the operating system to use bash as our 
command interpreter. 

xset s noblank, xset s off, xset -dpms - These commands stop the 
screensaver function and the desktop environment from interfering with 
our display 

unclutter -idle 0.5 -root &- This stops the mouse pointer from 
displaying on the screen 

The two sed lines stop any flags or pop-up warning bars, which would spoil 
the clean kiosk experience. 

The line beginning /usr/bin/chromium-browser specifies which websites 
appear in the Chromium browser in full-screen mode, and stops any user 
interaction with the sites. (You might not always want to prevent this, but in 
our example here we do, because we're making an information-only kiosk.) 
Finally, the while true lines are instructions to switch viewing between 
the two sites every ten seconds. During normal web browsing, the 
keyboard shortcut CTRL+TAB will cycle through the currently open 
browser tabs. Our script uses one of the packages we installed, xdotool, to 
do this by creating automatic keystrokes. 
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Ben Everard 


W @ben_everard 


Ben's house is slowly 
being taken over by 3D 
printers. He plans to 
solve this by printing an 
extension, once he gets 
enough printers. 


Below & 
You can grab the 
code from GitHub 


meterration2040w tahmover c 


aspberry Pi Pico W is a fantastically 

powerful development board, but, 

like many, it’s limited to a puny 3.3V, 

and the GPIOs can only handle a 
h smattering of microamps. This is fine 

for blinking LEDs, but if you want to run 
motors, or interact with more powerful components, 
you're going to need extra circuits. There's a whole 
host of options for this, including relays, motor 
drivers, and power MOSFETs, and you could add 
them to Pico W yourself. Fortunately however, the 
good folks at Pimoroni have already done this for you. 

In this article, we'll look at working with the bare 

Pico 2040 W board and the Automation 2040 W. 
The latter beefs up most of the components: the 
analogue inputs, four input lOs, three output IOs, 
and three relays can all handle up to 40V. In other 
words, it’s a great device for integrating with a huge 
range of equipment. 


ROT O t+ PCE 
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The Automation 2040 W doesn't come with any 
firmware, as it’s up to you to write code that makes 
sense for your project. Obviously, this could be a 
huge range of different things, depending on what 
you use the board for. To give you a sense of what's 
possible, we'll look at building a web interface that 
runs on Pico W and controls the inputs and outputs. 

While there is quite a bit of circuitry on this board 
to handle higher voltages and currents than a bare 
Pico W, we control all this with GPIO pins, just as 
if we were controlling lower voltages. So the same 
technique will work on other Pico W-based boards. 

In fact, we've also built a firmware for Pico W. 
The slight difference here is that, unlike Automation 
2040 W, any pin can be either input or output. We've 
arbitrarily split the pins roughly in half, but you can 
change this so that whichever pins you like do 
whatever you like. 

Before diving into the project, let's think a little 
about what our code should do: 


e It should work with or without an existing 

WiFi network 

e It should be able to read and display all the 

digital inputs 

e It should be able to read and display all the 

analogue inputs 

e It should be able to control all the outputs 

e It should be able to control all the relays 

e You should be able to control the outputs easily 
from a program running on another machine. 


In this tutorial, we'll work backwards. To start, we'll 
show you how to flash the finished firmware onto 
your Automation 2040 W, and then we'll show you 
how it all works. 


First, download the firmware for Automation 
2040 W from hsmag.ce/Automation2040; or 
for Pico W, from hsmag.cc/picowtakeover. In 
both cases, the compiled firmware that you want 
to use (at least at first) is xyz_wireless_ap.uf2. 
You can flash this to your board by unplugging the 
USB (if connected), then holding down BOOTSEL, 
and plugging it back into your computer before 
releasing BOOTSEL. 

You should then see a wireless network called 
Picow_test, and you can log into this with the 
password password. This isn’t the most secure 
option available, and should really only be considered 
a test mode. You can change the SSID or password 
in the code and recompile if you want to. 

Once you've logged into that network, point your 
web browser to 192.168.1.4 and you'll see a web 
page with the basic stats of the IOs. You can see if 
the inputs are high or low, if the outputs are on or 
off, and what the voltage at the analogue inputs is. 


a 
The very simple web server 
running on Pico doesn’t 


" 


really pay much attention to 
the URL you send to it 


The very simple web server running on Pico 
doesn't really pay much attention to the URL you 
send to it. 192.168.1.4 is the IP address of the 
server, so you have to head there. It only listens for 
an HTTP request — it doesn't really care about the 
actual location you're requesting. 

However, it does listen for parameters. In URLs, 
these come after a question mark, and multiple 
parameters are separated by an ampersand. 

The two parameters this server is particularly 
looking for are GPIO and state. Visiting the page 
http://192.168.1.4/?GPIO1&state=1 will turn GPIO 
1 on; visiting http://192.168.1.4/?GPIO1&state=0 
will turn it off. For general use, you don't need to 
know this, as there are links on the page to turn the 
lOs on or off. Note that the GPIO parameter refers 
to the actual GPIO number on Pico W rather than 
what is printed on Automation 2040 W. 

So far, so straightforward. There are a couple of 
things that you might want to change: the look of the 
web page and the networking. To do either of these, 
you need to recompile the code. You can do this 
either by downloading and installing the toolchain, 
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see hsmag.cc/PicoSDKSetup or by running it in a 
Google Colab environment (see box). 

The CMake builds are called automation2040w_ 
takeover and picow_takeover. 

Now you've got a way of compiling the code, 
let's take a look at how you might want to change it. 
First, let's examine how it generates the HTML for 
the page. There's a framework for the HTML that’s 
stored in the macro HTML_SOURCE: 


Above ® 

Pico W is a great 
device for quickly 
adding wireless 
connectivity 


#define HTML_SOURCE "<html><head><title>Automation 
2040W Takeover</title></head><body><h1>Automation 
2040W Takeover</h1> \ 
<p>%s</p><h2>ADC</h2><p>%s</p>\ 
<h2>GPIO Inputs</h2><p>%s</p>\ 
<h2>Relays</h2><p>%s</p>\ 
<h2>GPIO Outputs</h2><p>%s</p></body><htm1>" 


For those of you familiar with C, this should be fairly 
straightforward. If you're not, it might look a bit odd, 
but the basic thing you need to know is that macros 
created with a #define command will insert the string 
wherever HTML_SOURCE is in the code — in essence, 

it acts a lot like a variable (albeit a constant one). 
The %s is part of C's string formatting and identifies 
where we want other strings to be placed. > 


GOOGLE COLAB 


Installing the Pico SDK on macOS or Linux is 
straightforward, but on Windows it's a bit of a pain. 
Fortunately, there is a solution — run it in the cloud. 
Google's Colab environment gives you an interface to 
an online virtual machine running Linux. You can open a 
page setup for this at hsmag.cc/BuildingBlink. 

This walks you through how to compile the pico- 
examples, but you can use exactly the same process 
to compile your own code provided that you keep it on 
GitHub (or another online Git repository). 

How long this process will work for depends on how 
long Google keeps Colab going. Given the firm's history 
of killing projects, it's possible that you might find this 
suddenly no longer works in the future. 
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tutorials. Find out 
more at hsmag.cc. 


These strings are generated a bit later in the code. 


First, there is a string with what (if any) GPIOs were 
updated during the page load: 


int update_state = snprintf(update, 32, "<p> GPIO 
%d updated to %s</p>", gpio, state?"on":"off"); 


Then we generate text for the analogue inputs: 


#define NUM_ANALOGUE_GPIOS 3 
int gpios_analogue[] = {26,27,28}; 


char gpio_analogue_lines[500] = ""; 
const float conversion_factor = 45.0f / (1 << 12); 
counter = 1; 
for(int i=@; i<NUM_ANALOGUE_GPIOS; i++) { 
if (gpios_analogue[i] == 26) { 
adc_select_input(Q); 
} 
if (gpios_analogue[i] == 27) { 
adc_select_input(1); 
} 
if (gpios_analogue[i] == 28) { 
adc_select_input(2); 
} 
if (gpios_analogue[i] == 29) { 
adc_select_input(3); 


uint16_t result = adc_read(); 
snprintf(line, 64, "ADC %d has an 


analogue voltage of %f<br>", counter, 
result*conversion_factor); 
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strcat(gpio_analogue_lines, line); 
counter++; 


As you can see, we build up line-by-line the text that 
we want to go in the analogue output. 

The snprintf function is used to insert bits of text 
into a string. It’s based on a format string which 
can include format specifiers where we want to 
put in a bit of data. Previously we used %s to insert 
a string. Here, we're using %d for an integer and %f 
for a floating-point number. The full parameters are 
(output_variable, format string, data, ...). 

We use the strcat function to add one string to 
the end of another, so here gpio_analogue_lines is 
built up from all the bits of text joined together. 

We won't go through all the code here, as it is fairly 
similar, but the output GPIOs are: 


#define NUM_OUT_GPIOS 3 
int gpios_out[] = {16,17,18}; 


char gpio_out_lines[500] = ""; 
char line[64]; 
int counter = 1; 
for(int i=0;i<NUM_OUT_GPIOS;i++){ // get current 
GPIO values NOTE -- WORK OUT WHICH ONES are 
causing a problem 
if (gpio_get(gpios_outL[il)) { 
snprintf(line, 64, "Output %d 
is on, turn <a href='/?GPI0=%d&state=0 ' >of f</ 
a><br>", counter, gpios_out[i]); 
} 
else { 
snprintf(line, 64,"Output %d is 
off, turn <a href='/?GP1I0=%d&state=1 '>on</ 
a><br>", counter, gpios_out[i]); 
} 


counter++; 

strcat(gpio_out_lines, line); 
Here, you can see how we add an <a> tag to the 
line to create a link with the parameter to toggle the 
GPIO depending on whether it’s currently on or off. 


All these bits are then brought together with: 


char html_string[2000] = ""; 


snprintf(html_string, 2000, HTML_SOURCE, update, 
gpio_analogue_lines, gpio_in_lines, gpio_relay_ 
lines, gpio_out_lines); 


You can easily tweak these lines to output whatever 
HTML you like, but you need to be aware of a couple 
of things. Firstly, strings in C have a fixed maximum 
length. This is what's in the square brackets at 
where the variable is defined. Strings are really just 
arrays of individual characters. 

Secondly, there’s also a maximum length for the 
output buffer. This is the result element here: 


typedef struct TCP_CONNECT_STATE_T_ { 
struct tcp_pcb *pcb; 
int sent_len; 
char headers[128]; 
char result[2048]; 
int header_len; 
int result_len; 
ip_addr_t *gw; 
} TCP_CONNECT_STATE_T; 


NETWORKING 
By default, the program will create its own wireless 
network. The code that does this is: 


#ifdef WIFI_SSID 
printf("Connecting to WiFi...\n"); 
cyw43_arch_enable_sta_mode(); 
if (cyw43_arch_wifi_connect_timeout_ms(WIFI_ 
SSID, WIFI_PASSWORD, CYW43_AUTH_WPA2_AES_PSK, 
30000)) { 
printf("failed to connect. \n"); 
return 1; 
} else { 
printf ("Connected.\n"); 


printf("Starting server at %s \n", 
ip4addr_ntoa(netif_ip4_addr(netif_list))); 


#else 
const char *ap_name = "picow_test"; 
const char *password = "password"; 


cyw43_arch_enable_ap_mode(ap_name, password, 
CYW43_AUTH_WPA2_AES_PSK) ; 


ip4_addr_t mask; 
IP4_ADDR(&state->gw, 192, 168, 4, 1); 
IP4_ADDR(&mask, 255, 255, 255, Q); 


// Start the dhcp server 
dhcp_server_t dhcp_server; 
dhcp_server_init(&dhcp_server, &state->gw, &mask); 


// Start the dns server 

dns_server_t dns_server; 

dns_server_init(&dns_server, &state->gw); 
#endif 


As you can see, this is wrapped in a preprocessor 
if statement. For people not familiar with C, the 
preprocessor is a text formatter that runs before the 
main compiler. What this says is that if we define 
WIFI_SSID, then include the code up until the #else; if 
we don't, include the latter part. 

The define of WIFI_SSID is done in two stages. 
First, we can send definitions to CMake when we 
create our build files with a line like: 


cmake .. -G”NMake Makefiles” -DPICO_BOARD=PICO_W 
-DWIFI_SSID=yourssid -DWIFI_PASSWORD=yourpassword 


We can then get these defines to flow through 
into the C preprocessor with the following in the 
CMake file: 


if ("${WIFI_SSID}" STREQUAL "") 
message("Wifi SSID not defined, so will work 
in AP mode") 
else() 
message("Wifi SSID defined, so will work in 
station mode") 
target_compile_ 
definitions(automation204Qw_takeover PRIVATE 
WIFI_SSID=\"${WIFI_SSID}\" 
WIFI_PASSWORD=\"${WIFI_PASSWORD}\" 
) 
endif () 


All this means that you can select your network 

to connect to when you run CMake, but if you 

don't send any details there, it will create its own 
access point. If you connect to an existing network, 
your IP address won't be 192.168.1.4 — instead, it'll 
be assigned by your network. If you connect to the 
USB serial connection, you'll see the IP; alternatively, 
if you can access your router, you should see the 
device listed there with its IP address. 

Automation 2040 W and Pico W are great options 
for adding connectivity to non-connected devices. 
Here, we've shown one way to easily let you control 
them from your laptop or mobile phone, but there 
are loads of other options. O 
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Flip the Automation 
2040 W over for 
details of how to 
connect it 
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Use code and components T 
to make art, music, and much l 


more thanks to Pico 


aking isn’t just about writing code and “S 
controlling robots - knitting, carpentry, 
painting, and much more can fall under 
the umbrella of making. We love to see the broad 
range of ways people can get creative in making, 
especially when a Raspberry Pi is involved. 
With Pico, there’s even more ways to be artistic 
or add some electronics to a different kind of 
craft. Let’s see where we can squeeze one into... 


“ 
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Use lights and paint with Pico 
to make something amazing 


b 


Using conductive paint such as the stuff from 
Bare Conductive (bareconductive.com), you can 
connect physical painted art to a Pico. LEDs can 
be controlled for light-up maps or drawings, and 
you can even try out low-power servos as well 
for something a little more interactive. With Pi 
Cap from Bare Conductive, you can also add some 
capacitive touch response. 

There’s also a load of great simple projects 
from Bare Conductive you can take a look at here: 
magpi.cc/bcprojects - although they’ll need a 
little translating to work with Pico properly. 


MAGrT 


Light painting is a bit of a trick - you're not actually 
painting with light, you're just using maths and a long 
exposure time to create something that only exists in 
camera. However, it is an exceptionally cool existence. You 
can do it with bikes with lit-up spokes, special LED strips, 
and much more to make incredible stuff. Check out one 
way here: magpi.cc/lightpainting. 
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now better than ever with Pico 
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oF í A It’s impossible to miss Sean O’Steen when 
< ` he’s wearing his very colourful beret - in fact, 
` % that’s the point of it! At its most basic, this beret 
N N a > | has LEDs around the brim powered by a Pico W 
P P y 
Cyber G la running through a series of preprogrammed 
i animations for the individual lights. However, it’s 
AN, These glasses 0 also network-enabled, allowing you to connect to 
D it with your phone. 
PRN 3 Sean uses Pico W’s networking functionality 
: eet) to use the beret as a signalling system, letting 
AS 
Y ELS people nearby know in a busy convention hall if 
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When sewing electronics into 
a costume, you can make 

use of conductive thread to 
connect electronics to Pico, or 
other controller, much more 
discreetly. They're safe to wear 
and can be sometimes easier 
to connect than some wires - 
depending on the project. You 
can grab some at Pimoroni here: 
magpi.cc/conductthread. 
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Smart badges 


Badger 2040 is a great 
little screen that easily works as 
a badge once connected to clothing - we've 

used it at cons ourselves in the past. It uses an e-ink 
display, so it doesn't need to be constantly connected 

to power to display your name, but you'll need to quickly 
plug it in to change to another preprogrammed screen. 
Grab them here: magpi.cc/badger2040. 


Ea 


A classic wearable project updated for Pico. This 
Pip-Boy 2040 project was made by our friends at 
Adafruit and uses a Feather RP2040, a variant of 
Pico that is much smaller but still includes a full 
screen and usable buttons. 

The code for this is a simple slide show; 
however, it is very easy to add more interactive 
screen modes by tweaking it in Python. The most 
difficult part is building the physical thing, and 
this tutorial has you well-covered there. 


magpi.cc/pipboy2040 


Colour 
Costume 


Game Boy Color Costume >? 


á 
z This is not the first time we've seen a wearable giant Game 
a = Boy powered by Raspberry Pi, and we doubt it will be the 
> “A last because it is a very fun build. You could even turn 
yourself into a Game Gear or a Super Nintendo with an 
= almost identical build. Check out one recent build here: 
Oi ere) 


magpi.cc/gbcosplay. 
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Despite not having an audio jack, you 
can do a lot of musical things with Pico 


Built using Trill touch sensors, this MIDI Guitar 


was a 
years 


tutorial series in The MagPi a couple of 
ago, starting in issue 102 (magpi.cc/102). 


It works much like a guitar, with ‘frets’ at 
different spots up the neck, and a touch sensor 
for strumming. You can change the tuning 


as we 


l, which is shown on a little screen on 


the headstock. 

The body itself is a fun bit of woodworking too, 
gh you can always transpose the system 
different body entirely - maybe even into a 


althou 
into a 


weara 


ble, musical sleeve? 
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Instead of soldering a speaker to 
your Pico, this add-on allows you to 
have high-quality audio output from 
Pico through 3.5mm jacks. It connects 
to Pico like a HAT on Raspberry Pi. You 
can even choose to manually amplify each 
output. Grab one here: magpi.cc/audiopack. 


Pico Piano 


This clever project uses a copper-plated board 
with piano keys etched into them and a series of 
resistors to create variable currents at each key. 
The piano player then uses a jumper cable hooked 
up to a Pico which senses the different current 
values and plays a note based on it. 

This use of resistors would be very difficult to 
do on Raspberry Pi without other components. 
If you don’t have access to copper boards and 
etching solutions, you can use a perf board as 
well to create a piano. 


magpi.cc/picopiano 
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MIDI controller 


There are a couple of great DIY 
MIDI controller projects for Pico - we 

quite like the MIDI Fighter that uses arcade 
buttons (magpi.cc/midifighter) - however, if 
you just want to experiment with code and don't 
want to do too much physical building, Keybow 2040 from 
Pimoroni is a great customisable keyboard that can be 
used as a MIDI controller with some coding. Get it here: 
magpi.cc/keybow2040. 


Lo-Fi Orchestra 


This massive orchestra is made up of various 
microcontrollers and microcomputers, and nearly every 
week we get to hear something new from it. We quite like 
the version of Gustav Holst's The Planets suite composed 
on it. You can find out how it works with the very thorough 
blog here: magpi.cc/Lofiorchestra. 
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GIFT GUIDE 


THE BEST NEW PRODUCTS YOU CAN BUY 


Immerse yourself in the game with the curved 
GB3467WOSU Red Eagle with FreeSync Premium. 

Inspired by the curve of the human eye, the 1500R curved 
VA panel with 165Hz refresh rate, 0.4ms MPRT, and 3440x1440 
resolution guarantees superb image quality and a comfortable 


and very realistic viewing experience. 

The height-adjustable stand ensures total flexibility for your 
perfect screen position. Customise the screen settings using 
the predefined and custom gaming modes along with the Black 
Tuner function to give you total control over the dark scenes and 
make sure details are always clearly visible. 


FOR CHRISTMAS AND INTO 2023 


The Skip 1s Universal Remote Control makes controlling 
your entertainment center a breeze. With support for 
three different activities that can be activated with the click 
of a button, a universe of device combinations is at your 
fingertips. Leave the simplicity to us, and we'll leave the 
creativity to you. 


ADVERTISING FEATURE 


The AOC 027G2E/BK offers a 27-inch VA panel with 

QHD resolution, ShadowControl and super contrast ratio 
of 3000:1. Enjoy the most responsive gameplay and fastest 
battles with its stutter-free Adaptive Sync, 155Hz refresh rate, 
1ms MPRT, and low input lag to decrease motion blur and 
input-output delay. Gaming has never been so fun and intense. 


A custom gaming PC from Cyberpower UK is a perfect 
treat this Christmas season. With hundreds of parts to 
choose from — including NVIDIA's GeForce RTX 4080 GPUs — 
its cutting-edge configurator tool lets you build your dream spec 
from scratch and finish it with a custom engraved side panel. 

Order your gaming PC by 12 December, or pick up a pre- 
built one by 21 December, for guaranteed Christmas delivery, 
free UK delivery, and an extended return warranty for all 
holiday shoppers. 


Mini Pupper is an Al-powered, smart, quadruped robot 
designed for education. Mini Pupper makes robotics easier for 
schools, home-school families, enthusiasts, and more. 

Utilising ROS (Robot Operating System) and with support for 
OpenCV and OpenCV's official OAK-D-Lite 3D camera module, 
this open-source robot is powerful and super-expandable. 


Unleash your potential with this 240MHz, 27-inch display. 
Its 240Hz refresh rate, 0.5ms response time, and low input 
lag enable the AOC C27G2ZU to provide a perfectly smooth 
performance. With its curved design, height adjustment, and 
swivel ability, the monitor can be adjusted to individual needs. 
It comes with FreeSync Premium and G-Sync compatibility. 
The C27G2ZU/BK is on a Black Friday promotion at £189, 

which may continue depending on stock, so pick one up early 
if you find it on sale. 
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reTerminal E10-1 


CONNECTIVITY: 
RS-485, RS-232, 
CAN, RJ45 Gigabit 
Ethernet, M.2, 
Mini-PCle, mobile 
network, wireless 
LAN 


DIMENSIONS: 
140mm « 95mm x 
30mm 


Verdict 


A great, if bulky, 
expansion for 
reTerminal 

that seems to 
address any prior 
connectivity issues. 


9, 10 


> Seeed studio >» magpi.cc/reterminale10 » £91/S109 


An expansion board for the industrial-focussed 
reTerminal computer brings much more functionality, 
as Rob Zwetsloot discovers 


4, reTerminal is a very functional and 

powerful industrial computer. It was 
missing a little bit of connectivity for some use 
cases though, most of which have been addressed 
with a pretty beefy expansion board. 

We do mean beefy too - it’s larger than 

the original reTerminal, and attaching it does 
increase the footprint (and weight). However, 
for that sacrifice you do get a barrel DC jack, a 
battery compartment, PoE, improved wireless 
LAN, mobile network support, serial ports, 
microphones, and speakers for any machine 
learning application, and the ability to add much 
more storage via SATA 2.0 and M.2 drives. 


p owered by a Raspberry Pi Compute Module 


A The connected 


system is larger, but 
fits together nicely 
with no overlap 
from the front 


as well, so any portable power you put in won’t 
accidentally fall out. 

Attaching the expansion to reTerminal is very 
Safely secured easy - it slots into a port covered by a rubber foot 
Adding storage isn’t just a case of slotting in an 
SD card - the whole expansion kit comes apart 
so that you can install any drives into the very 
sturdy case so you’re not losing any protection. 
The battery compartment is attached by screws 


m The whole expansion kit 
comes apart so that you 
can install any drives into 


LULU the very sturdy case Ø 


on the rear end, and is then secured with a couple 
of provided screws. No friction or plastic clasps 
Py EE) » a are used so there’s no danger of the connector 
wearing out, so to speak. 
j With that connection, you just need to 
g install a driver and a Python library to the 
main reTerminal and you’re ready to go and 
incorporate the expansion into the system. It’s 
very easy and will definitely help with connecting 


A The expansion port uses a 100-pin 
to older hardware. m 


industrial high-speed interface 
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> From £26 / $31 


MICROCONTROLLER: 


ESP32 


CONNECTORS: 
Relays x 4,5 x3 
component pins, l2c 
breakout, USB micro 
data port 


RADIO: 
Wi-Fi, Bluetooth 4.2, 
BLE 


Warning! 
Mains Electricity 


Relays can be very 
dangerous as they 
convert high currents. 
Only use one if you're 
experienced: 


magpi.cc/ 
electricalsafety 


> The board is fairly 
compact but well laid 
out to keep the relay 
side away from any 
parts you'll work with 
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> CoreData >» magpi.cc/relayfi 


A 4-channel smart relay board with ESP32 and many 


loT connections for a lot of home automation 
control. Rob Zwetsloot puts it to the test 


to use IoT over a Wi-Fi network - in 
fact when Raspberry Pi Pico first came 
out, several add-on boards added Wi-Fi 
using it. Unlike Pico, RelayFi is much more 
focussed towards home automation, while 
also in a fairly small package. 

The four relays take up most of the board and 
handle conversion and control for four mains- 
powered devices. We highly suggest getting some 
kind of case for the board as there are solder 
points on the underside of the PCB. These relays 
are controlled via an optoisolator which does 
improve the safety of the relays and, despite 
there being four squeezed onto the board, the 
screw terminals have a decent amount of space 
between them. Still - caution is recommended 
with this, like any other relay. 


E SP32 devices are a more traditional way 


Connecting 

to things 

With a series of 12c 
and standard component 
pins, you can add a little 
extra control to the board that 
is all programmed using the 
classic Arduino IDE. As it’s 

all Wi-Fi connected, having 


A USB micro is used 
to power and 
program RelayFi 


m RelayFi is much more 
focussed towards home 
automation, while also in 
a fairly small package Ø 


it talk to a Raspberry Pi or Pico W is a matter of 

making sure it’s looking 

for the right thing. Like . 

an Arduino board, a micro Ve rdict 

USB port is used to power 

and connect to it for A solic lor 

programming, which also poara:Withi easy 
: programming 

supports various smart functions that 

home systems for voice can interact with 

Raspberry Pi 
just fine. 


control via RelayFi. 
Í /10 


It’s a fairly solid build 
for such a relatively cheap 
board, and the ease of 
coding helps with its 
appeal as well. H 


TECHNOLOGY IN YOUR HANDS 


Tm MAGAZINE 
MODERN MAKER 


TE 
Ua ckS HACK CREA 


kSpace 


HackSpace 


SAVE AND 


SAVE 


35% 


PE EEr RIER 


kz 
rid IN Cr HA 


RASP 


oe e wo! d’s $ CR T | 
e CHD kS 
DIY buile m T ‘an : ye 


RASPBERRY PI 


4 PROJECT 


DIY builds with the worid's 
avourite =x comput 


RADIO 
E CONTROL 


BUILDS 


ISSUE #62 


OUT NOW 


hsmag.cc 


At | @& AppStore | oe GETITON 
É Appstore AppStore | | P> Google Play 
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10 Amazing: 


Advanced 
projects 


Do more with your Pico and Pico W 
with these excellent add-ons 


with coding and making. However, it’s also used 

in industry for some really high-tech applications. 
While we’re celebrating newcomers elsewhere in the mag, 
on these pages we have some more mature projects for 
Raspberry Pi veterans to get stuck in to. Hl 


R aspberry Pi is great for people just starting out 


a Raspberry Pi cluster 


Parallel power 


Turn several Raspberry Pi into your own sorta-supercomputer with 
some pretty decent parallel processing power - and a 1TB SSD. 


magpi.cc/cluster 
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mastodon 


a Host your own Mastodon instance 


Social media alternative 


The official Raspberry Pi Mastodon server is hosted on a Raspberry Pi 
server - here's how you can make one for yourself. 


magpi.cc/mastodon 


v Web server 


66 


Online hosting 


Setting up and operating a web 
server involves several layers 

of different software, including 
databases, admin Uls, front ends, 
blog themes, etc. 


B 


OctoPrint 


magpi.cc/webserver 


a OctoPrint 


Social media alternative 


A web interface for 3D printers 
powered by Raspberry Pi and full 
of fun plug-ins - like taking a time- 
lapse video so you can see your 
print build up (or flop) like magic. 


octoprint.org 
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Legends of ED murs 


a Game development 


Make interactive stories 


From visual novels to MicroPython platformers, there are a lot of ways to 
make games on Raspberry Pi, and you can even publish them on itch.io. 


magpi.cc/gameresources 


v Face recognition door-lock 


Automated security 


This great Digi-Key tutorial uses 
a mixture of machine learning 
and actuators to make sure only 
the right people can enter a 
door. Don't run it past the Lock 
Picking Lawyer though. 


magpi.cc/faceid 


a PiCar radio 


Upgraded audio 


Featured earlier on in this issue, this is a custom-made entertainment 
system for a Jeep Wrangler that aims to maintain the aesthetic of the 
stock radio. 


magpi.cc/picar 
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3D-printed flyer 


Raspberry Pi has gone pretty high - several are in low Earth oribt - 
and thanks to 3D printing and smaller electronics, it’s not too tricky 
to make your own flying Raspberry Pi drone. 


magpi.cc/builddrone 


4 Underwater drone 


Submersible photos 


Waterproofing electronics can be tricky - and remote controlling 
them underwater is trickier still due to physics. This fantastic project 
manages to solve a lot of these issues. 


magpi.cc/80 


> Pi-hole 


Network security 


Ads are a prime vector for 

malware online, and whether 

you have a small office or a home 
network to maintain, Pi-hole is a 
great way to keep your browsing safe. 


pi-hole.net 
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Learn web design 
with Raspberry P1 


Set up your own websites with Raspberry Pi 


f introduction to web development 


The internet remains central 
to our lives, and creating 


Future Learn 


Price: websites is the best way to get 
a information across to a range 
magpi.cc/ 


of people. Plus, web design and 
development is a foundational 
skill that all coders should have. 
Raspberry Pi is ideal for 
integrating with websites. 
As well as acting as a regular 
computer, it can be set up to 
act as a server to deliver web 
pages. And with its physical 
computing interface, Raspberry 
Pi integrates real-world items 
(such as sensors or motors) 


flintrowebdev 


with online websites. 
This allows you to 
remotely control 3 > 
and monitor an 
environment via 


putre 
F teom 


a website. 

HTML, CSS, 
and JavaScript S 
are cornerstone m 
technologies for 23 = 


website development. 
Raspberry Pi’s 
Future Learn course has all of 
them covered. 

This free course covers HTML 
tabs, styling with CSS, and 


Introduction to Web Development 


+ PHM Yea : 


? = 


= ‘5 Be, a 


Sirs 
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creating interactive elements 
with JavaScript. And you get 

a digital certificate at the end 
of it too. Hl 


Read up on web design 


HTML & CSS 


Jon Duckett's twin book set for 


web designers and front-end 
developers is a lovely pair of books 
packed with detailed information 
in a clear and useful style. 

> htmlandcssbook.com 


THE PRINCIPLES OF 

BEAUTIFUL WEB DESIGN 
If you want to make websites 
that don't just work, but look 


wonderful, this is the book to pick 
up. It’s packed with great designs. 
> magpi.cc/beautifulweb 


LEARNING WEB DESIGN 
Jennifer Niederst Robbins's book 
is the place to start if you are an 
absolute beginner. It takes you 
through building web pages that 
work using the very latest HTML5 
and CSS3 code. 

> learningwebdesign.com 
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E introduction to UI & UX Design 


Codecademy ee ee 
; Ek 

Price: mascs 

Free (£20/$25 Pro plan). po 

magpi.cc/ a 

codecademywebdev even 


Codecademy has a huge range 
of tutorials for coding and 
web development. What makes 
Codecademy special is the 
gamified interface that makes 
it fun, and rewarding, to learn. 
It’s especially well-suited 

for beginners and relatively 
simple subjects. 


All the core subjects, such as 
HTML, CSS, and JavaScript, are 
free. Plus there are some great 
web-integrated coding tutorials 
for Ruby, Node.js, Lua, and PHP. 
The Pro track offers up full- 
stack, front-end, and back-end 
engineering paths if you are 
looking to kick-start your career. 


{i Mythic Beasts 


In the background of 
websites are server systems. 
Price: These are the computers 
£5/$6 (per month) that serve up web pages and 
web-based applications. 
Raspberry Pi is ideal for 
deployment as a web server as 
it’s reliable, with low power 
requirements. Raspberry Pi can 
be connected to the internet 
and left for long periods. You 


Mythic Beasts 


mythic-beasts.com 


Raspberry Pi 4 servers * 


can create your own web server 
using Raspberry Pi. 

Most people hire out space 
on a shared web server, letting 
another person manage the 
server control. Mythic Beasts 
is the best of all worlds, a 
Raspberry Pi-based server 
company. You can get your 
own Raspberry Pi-based server, 
or sign up for cheaper shared 
hosting. It’s a great way to 
run your own website and an 
extensive support system shows 
you everything from web and 
email hosting, to creating your 
own virtual Linux space and 
backup server. And because 
it’s Raspberry Pi-based, it’s 
cheaper, more reliable, and 
familiar for Raspberry Pi 
fans. There’s a huge range of 
tutorials and support. m 
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Bookmark these pages 


PENGUIN TUTOR 

Stewart Watkiss has put 
together a great page packed 
with information on building a 
website with Raspberry Pi. 

> magpi.cc/ptwebsite 


SET UP ALAMP SERVER 
Our very own tutorial shows 
you how to create your own 
LAMP (Linux, Apache, MySQL, 
PHP) server using Raspberry Pi. 
> magpi.cc/lamp 


Learn to Code 


W3SCHOOLS 

Packed with tutorials and 
reference guides, W/3Schools 
will help you understand every 
single concept of web design 
and development. 

> w3schools.com 
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Jeff 


Geerling 


Ex-engineer, now YouTuber who still does a lot of great engineering 


> Name JeffGeerling | > Occupation YouTuber 
> Community role Maker | > URL jeffgeerling.com 


etting your kids into 
G your interests and work 

is a bit hit or miss. 
You can never force anyone to 
like anything. Luckily for Jeff 
Geerling’s Dad - and maybe Jeff 
himself - he was able to share 
his interests. 

“My Dad would bring random 
bits of computer hardware and 
electronics home from work, 
and he let me use his workshop 
to build things,” says Jeff, a 
tech YouTuber who covers a lot 
of computer-based topics. “He 
encouraged me to try things 
until they worked, and instilled 
in me the ‘hacker’ spirit, where 
you learn by doing something 
wrong a few dozen times, until 
it works. 

“And sometimes you 
accidentally short a computer’s 
power supply and end up with 
a burn on your finger and a 
dead computer!” 


When did you first learn about 
Raspberry Pi? 

I remember reading about the 
first board on Ars Technica in 
early 2012. I bought my first 
Raspberry Pi (a Model B) on 
September 12, 2012, and gave it 


to my brother a few years later, 
after I started using Raspberry 
Pi 2 for my experiments. 


How did your YouTube career 
get started? 

I started making videos in the 
late 1990s, mostly for family and 
friends on my old Power Mac. In 
2006, I started posting a few of 
my home videos on YouTube - a 
couple are still live today! I didn’t 
dedicate much effort to YouTube 
until the pandemic. I had a bit 


make a lot less than I used to, 
but it’s enough. It sustains 
my family of six and pays the 
medical bills - I have Crohn’s 
disease and it can be difficult 
having a chronic illness! 


What are some of your favourite 
Raspberry Pi projects that you 
have made? 

After the Compute Module 4 
came out, I had a dream to 

build a one petabyte Raspberry 

Pi - one single Raspberry Pi 


m | learned a bit on that project, but 
what made it enjoyable is how much 


my kids loved it Ø 


of luck with a live-stream series 
I did called ‘Ansible 101’, along 
with some videos about building 
a Kubernetes cluster with 
Raspberry Pi computers, and my 
channel grew quickly. 

I calculated what kind of 
viewership I would need to make 
producing YouTube videos a 
viable business plan, and once 
I hit those numbers, I stopped 
doing software consulting. I 


with a 1PB storage volume 
directly attached. And I did it! 
That project took more than two 
years to pull off, and required 
help from Broadcom engineers, 
Raspberry Pi engineers, and 
45Drives, a storage company. It’s 
terribly impractical and barely 
worked, but it was the most fun 
I’ve had with a Raspberry Pi. 
My second favourite is a 
slapped-together Raspberry Pi 
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Jeff's website is hosted 
on a web server, in a barn, 
on a farm, powered by 
solar panels 


The petabyte cluster 
probably has enough data 
for a couple of 4K movies 


‘Red Shirt Jeff’ detector that 
used AI to blast Red Shirt Jeff 
with my leaf blower when he 
came into my office. I learned 
a bit on that project, but what 
made it enjoyable is how much 
my kids loved it. Seeing their 
uncontrolled laughter when the 
contraption worked the first 
time made that project much 
more memorable. 


This is Turing Pi 2, a 
cluster computer made 
from four Raspberry Pi 
Compute Module 4 


What Raspberry Pi projects do 
your audience love? 

According to YouTube statistics, 
people love Raspberry Pi clusters, 
or ‘brambles’, as I call them. It 
started with the ‘Dramble’ (a 
Raspberry Pi cluster running the 
Drupal website pidramble.com 
since 2014), and now I’ve built 
a number of clusters to run 
Kubernetes, K3s, and even run 
the Linpack benchmark to see 
where my Pi 4 cluster ranked in 
the Top 500 Supercomputer list 


à , e 
(it would ve been competitive When Jeff says he experiments, here is what he means: testing time 
back in 1999)! differences between different Raspberry Pi Compute Modules 
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MagP1 
Monday 


Amazing projects direct from our Twitter! 


very Monday we ask the question: have 
you made something with a Pi over the 
weekend? Every Monday, our followers send 
us amazing photos and videos of the things they 
have made. 
Here’s a selection of some of the awesome 
things we got sent this month - and remember to 
follow along at the hashtag #MagPiMonday! Hl 


01. We like the use of a (very) little LCD to 
maximise the power saving of the system 


02. We havea few Raspberry Pi trees we need 
to break out for our decorations 


03. Great to see updates to projects previously 
featured in the magazine! 


04. There's so much software that can help 
with stargazing on a Raspberry Pi 


05. You probably don't want to roll this dice 
for initiative 


06. This beautiful art piece is an interesting 
insight to modern data usage 


07. The displays get better and better with 
each passing week 


08. This PiMowBot branded remote control 
is adorable 


09. Acheerlights-enabled bauble is our kind of 
Christmas decoration 


10. Never be sorry about mince pies 


1. A place called Punpedia sounds upsetting 
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g Philip Heron 


Started working on a Pico W powered solar inverter 
monitor. Data is uploaded via Wifi and also displayed 
locally on a (very) little LCD. 


Normal Operation 
x 64.2U 3.28A 
240 U 50.02 HZ 


192 W 


A progra~1 


Merry Christmas 


& David Crump 


Finalising a 50 MHz Spectrum Display using a 
Raspberry Pi 4, 7 inch Touchscreen and an 

Pluto SDR to add to the Portsdown 
Amateur TV project featured in 


MéigPi 


My 55mm dice lamps use the rp2040 and circuit 


python: 


ontrol board 


‘cus control 


ate Colecago 


Dr Footleg - Roboteer @drfootieg@fosstodon... 


bir nted competing colours of cellular automata life in my run 


anywhere animations library. Running on a Raspberry Pi 4 here 


Watch again 


E) Kevin McAleer $È Robot Maier 


Happy ! This weekend | built the 
world's most advanced / over-engineered Christmas Brian Jamieson 
Tree Bauble! 


It has a builtin webserver and can run as 
well as other fun RGB LED Patterns, made with the 
Plasma Stick. 


(Sorry ©) 


I joined a cooking club. 


icl Fischer 


Artwork, detecting RF signals 
Spectral Surrounding 


| tinkered around with the Pico W and a 
IPS 1,14 display to craft a tiny 

RemoteControl for the PiMowBot using the 

PicoGraphics library for MicroPython from 


R Karin McAleer @ Robot Maker 


Happy ! 

This weekend I discovered Punpedia, which is like 

Wikipedia but for Puns... so I'm building an API to 

deliver puns to Pico W Projects, most likely the 
Inky Frame... API to be hoste 

new RPi 4 that | unboxed on 


Fix something that’s | 
Stoven in your house 
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£ Piotr Gaczkowski 
& Martin Parker 
4 0 


Physical visuals controlled by MIDI notes. The tree is Hey | put this up over the weekend and forgot to 
the guitar solo, the "moss" is the beat. mention it 


No N J $ Martin Parker 
No m 
ing home from taki 


0:37 745 views 


A 
~~ 


Well, we got our vo d Jonay Jovani 
ona ico onitc doo co 3 


Building and installing "PeatCams" to monitor peatland 
condition and hydrology by measuring peat subsidence 
and water table depth in tropical peatlands. Using 
Raspberry Pi 2B and 3B+ plus a range of different 
sensors 


We too have always thought of trees as 
guitar solos 


We like the nice wood fascia for this screen 


Combining these two projects makes a 
good case for tree lights up all year 


This is a really great bit of science 
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C4 = aspberry Pi projects you can 
Yj, Crowdfund this! 22.3" D 


PiTalk.. 


loT HAT for 8 Raspberry Pi & Dongle 


THE MOST CONVENIENT 
NETWORKING CHOICE FOR 
YOUR IOT APPLICATIONS 


Fichell g 


RASPBERRY PI 2,3 & 4 MODEL (8) 


PiTalk 


This 4G HAT for Raspberry Pi is designed with loT in mind. It 
supports a huge number of radio types, so it should work just 
about anywhere in the world. There's also a 2G version for slower, 
more low-powered applications, and a USB dongle version. 


PiShell 2 


A trendy and protective enclosure for Raspberry Pi, or so the 
blurb says. We like that is has a Raspberry Pi Camera Module hole 
on the top of the case, and even a slot for the DSI cable so you 
can connect it to displays while keeping the case closed. 


> kck.st/3iek836 > kck.st/3tpgA0d 


The Raspberry Pi Foundation enables young 
people to realise their full potential through 
the power of digital technologies, but we can't 
do this work without your help. Your support 
helps us give young people the opportunities 
they need in today’s world. Together we can 
offer thousands more young people across 
the globe the chance to learn to create with 
digital technologies. 


Generous donations from organisations and 
individuals who share our mission make our 
work possible. 


Raspberry Pi * 
Foundation 
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Fish-feeding apps 


Regarding the Automatic Fish Feeder Deluxe - will Erik make an iOS 
version of the software? 


Ted via email 


The software that you 
is a special app for the 
aforementioned fish 
feeder from issue 124 
(magpi.cc/124) - it’s a 
fairly simple app that 
A The app is fairly simple and can be used by communicates with the 

multiple phones on the same network fish feeder as long as it’s 
connected to the same network. It uses UDP multicasting tech for this, 
similar to how you might stream media over your network. This means 
multiple phones can connect at once. 

Building apps for iOS is a bit different from Android, so we’re not sure 
how easy a port it would be. The source code is available from his GitHub 
(magpi.cc/fishfeederapp), so if you have some know-how with iOS app 
programming, you can probably do some porting yourself - we’re reaching 
out to Erik anyway about it. 


Contact us! 


> Twitter @TheMagPi 


> Facebook magpi.cc/facebook 
> Email magpi@raspberrypi.com 
> Online forums.raspberrypi.com 
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wah 
HACKING amn 
MAKING 


A You can print out all PDFs 
that we release under the 
Creative Commons licence 


Print yourself 


Can out of print books such as The MagPi Essentials 
- Hacking and Making in Minecraft, now only 
available as free PDF, be printed externally at 
consumer expense, or does that breach terms? 
Apologies if this answer should be obvious 
elsewhere, thought I’d cut to the chase here. 


Brian via email 


Absolutely - our books and magazines are licensed 
under Creative Commons in a way that means you 
can print off the free PDFs. Not all of our books 
make it to print, and we can’t always reprint stuff, 
so we’re happy for you to do it - you just can’t 
then sell the printed copies or profit from them. 


USA SPECIAL! 


2 Sad er 


SUE 


Need an idea to get you started? Check out our top 
ten amazing Holiday projects article from issue 124 


I’m making something as a Christmas decoration, but I 
will have it finished only a few days before Christmas at 
the rate I’m going. Will that be too late to submit it for 
any kind of holiday project roundup? 


Naz7 via Twitter 


Due to the way making magazines works, our February 
issue is the one that will have any Christmas project 
roundups! That means that you have plenty of time to 
send us any holiday-themed projects that you might have 
before make the next magazine! 

Hopefully, we’ll have a few of our own to show 
you too! We have some examples of holiday 
projects in the previous issue as well, if you 
need some inspiration (magpi.cc/124). 


Subscribe online 
| magpi.cc/subscribe 


DEAD SPACE 


NME 


THE EVOLUTION OF 


PIXEL ART LOOKING AHEAD TO THE MOST BEAUTIFUL GAME oF 2023 


The secrets of The surprising Far Cry 6's level Code your own 
Monkey Island’s popularity of job designer on telling point-and-click 
world-building simulators stories via graffiti adventure 


WL 


\« 
N 


1 OF 10 Y 
RASPBERBY oN 
ZERO 2 W 


Start off the year with a 
Raspberry Pi Zero 2 W, 
the small yet powerful 
computer that fits all 
Raspberry Pi Zero 
accessories, and gives 
your projects a big boost 
in speed. We have ten to 
give away - enter now! 


Head here to enter: magpi.cc/win | Learn more: magpi.cc/zero2w 


Terms & Conditions 


Competition opens on 14 December 2022 and closes on 26 January 2023. Prize is offered to participants worldwide aged 13 or over, except employees of Raspberry Pi Ltd, the 
prize supplier, their families, or friends. Winners will be notified by email no more than 30 days after the competition closes. By entering the competition, the winner consents to any 
publicity generated from the competition, in print and online. Participants agree to receive occasional newsletters from The MagPi magazine. We don't like spam: participants’ details 
will remain strictly confidential and won't be shared with third parties. Prizes are non-negotiable and no cash alternative will be offered. Winners will be contacted by email to arrange 
delivery. Any winners who have not responded 60 days after the initial email is sent will have their prize revoked. This promotion is in no way sponsored, endorsed or administered by, 
or associated with, Instagram, Facebook, Twitter or any other companies used to promote the service. 
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English not your 
mother tongue? = 


The MagPi is also available in German! 


Subscribe to the German edition of 

The MagPi and get a Raspberry Pi Pico 
with headers and a cool welcome box 
FOR FREE! 


Use the coupon code TISPicoDE h : 


on www.magpi.de/115 
N 


Plus! 


Raspberry Pi 
Pinball Machine 


Spin up your own 
Mastodon server 


Programming 
with Scratch 


NEXT MONTH | MägPi . 


THE MAGPI #126 
ON SALE 26 JAN 


DON'T MISS OUT! 
magpi.cc/subscribe 


TWITTER 
FACEBOOK 
EMAIL 


@TheMagPi 
fb.com/MagPiMagazine 


magpi@raspberrypi.com 


EDITORIAL 

Editor 

Lucy Hattersley 
lucy@raspberrypi.icom 
Features Editor 

Rob Zwetsloot 
rob@raspberrypi.com 
Sub Editor 

Nicola King 


ADVERTISING 


Charlotte Milligan 
charlotte.milligan@raspberrypiicom 
+44 (0)7725 368887 


DESIGN 


criticalmedia.co.uk 


Head of Design 
Lee Allen 


Designers 
Olivia Mitchell, Ty Logan, 
Sam Ribbits 


Illustrator 
Sam Alder 


CONTRIBUTORS 


David Crookes, PJ Evans, Ben 
Everard, Rosemary Hattersley, 
Nicola King, Phil King, 

KG Orphanides, Toby Roberts 


PUBLISHING 
Publishing Director 
Russell Barnes 
russell@raspberrypi.com 


Director of Communications 
Liz Upton 


CEO 
Eben Upton 


DISTRIBUTION 


Seymour Distribution Ltd 
2 East Poultry Ave, 
London EC1A 9PT 

+44 (0)207 429 4000 


SUBSCRIPTIONS 


Unit 6 The Enterprise Centre 
Kelvin Lane, Manor Royal, 
Crawley, West Sussex, RH10 9PE 
+44 (0)1293 312193 
magpi.cc/subscribe 
magpi@subscriptionhelpline.co.uk 


This magazine is printed on paper sourced 
from sustainable forests and the printer 
operates an environmental management 
system which has been assessed as 
conforming to ISO 14001. 


The MagPi magazine is published by 
Raspberry Pi Ltd, Maurice Wilkes Building, 
St. John's Innovation Park, Cowley Road, 
Cambridge, CB4 ODS. The publisher, 
editor, and contributors accept no 
responsibility in respect of any omissions 
or errors relating to goods, products, or 
services referred to or advertised in the 
magazine. Except where otherwise noted, 
content in this magazine is licensed under 

a Creative Commons Attribution- 

NonCommercial-ShareAlike 

— | 3.0 Unported 
i| (CC BY-NC-SA 3.0) 
ISSN: 2051-9982. 


ME Magi | THE FINAL WORD 


Achievements 


Looking 
th 


past, I’ve definitely mentioned 

how I don’t like to live life with 
regrets - if it’s happened, you can’t 
change it, you can only learn from 
it. I do like to remind myself of good 
things that have happened in the past 
though, especially if they inspire me 
to do more in the future. This also 
means mentally rounding up the year 
I’ve had, in the hopes that I feel like I 
have accomplished something. 

In 2021 I struggled. I personally 
began streaming regularly and it turn 
outs that it really eats up your free 
time! Especially when you’re starting 
from scratch and needing to doa 
crash course in OBS, overlays, and 
sound boards. 

For 2022, I decided to make some 
goals and rough plans instead of 
stumbling into projects like I have in 
the past - and also promising to go a 
bit easier on myself if I didn’t achieve 
them all. 


| n one of these columns in the 


Still stumbling 

One thing I’m always proud of is the 
work we do on The MagPi. Pm 
especially happy when I get to make 
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something cool and talk about what 
I’ve learnt in the pages of the mag - 
this year, in particular, three projects 
stand out to me. 

Firstly, there were the quiz button 
boxes. After years of saying I’d make 
it, I finally created custom buzzers 
with programmable sounds and the 
ability to find out who pressed 


back at the year and planning for 
e next, with Rob Zwetsloot 


about using NeoPixels with Pico, 
which I then applied to some 
excellent Christmas lights that are 
shortly going up on my tree. 


Satisfaction guaranteed 
Other things I planned for the year 

- mostly personal stuff like make 
silly videos and write more fiction - I 


m i'm especially happy when | get to make 
something cool and talk about what 


I've learnt Ø 


buttons in what order. I’ve made 
some modifications since I put the 
tutorial in the mag and, at some 
point, Pll update the code on the 
GitHub as well. 

Otherwise, this year I got back to 
making cosplay props with the 
Poltergust G-00 I made with help 
from, 3D printing wizard and 
Raspberry Pi Maker in Residence, 
Toby Roberts. It was a bit easier than 
last time when I had to gut a real 
vacuum cleaner, and I learned a lot 


wasn’t always able to get to, but 
thankfully I did enough to be proud 
of. Maybe I also was able to be kinder 
to myself in the process as well! 
Anyway, I hope you all have a 
fantastic 2023. I’ll see you there. M 


Rob Zwetsloot 


Streaming may still be taking up a lot of 
Rob's time, but at least he gets to build 
robot models while doing it. 
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HiPi.io 


HIGHPI PRO 


.—— The new case from the HiPi.io team ———————-- 


® Rapid tool-free assembly and disassembly ® Secure microSD card cover 
@ Large internal volume for HATs @ VESA mount support 


@ Compatible with Pi 2/3/4 ® Molding-configurable output ports 


e Multiple lid options customizable for volume orders 
@ Passive & Active Cooling options @ Printed logo for your branding 


Available at these great Pi stores: 


Li 4 ew 
Æ PiShop.us {ef PiShop.ca {ef PiShop.mx C)zpinut PrSnoe.cn Welectron. 


Contact your favorite Pi store if it’s not listed here 


HIPI.10 


PIKVM 


Manage your servers or 
workstations remotely 


A cost-effective solution for data-centers, 
IT departments or remote machines! 


PiKVM HAT 


for DIY and custom projects Pre-Assembled version 


e Real-time clock with rechargeable super capacitor @ OLED Display e Bootable virtual CD-ROM 
& flash drive ® Serial console ® Open-source API & integration ® Open-source software 


Available at the main Raspberry Pi resellers 


QF )RPishop.cz Welectron. lektorsto rit | gO) 
Vés docavatet Raspberry P 


PrSnoe.ch CÉPiHut Š PiShop.us Ç$ Pishop.mx 


Scere 


TR 


Reseller suggestions and inquiries: 


wholesale@hipi.io 


